STM32八股【2】-----ARM架构
1、架构包含哪几部分内容
- 寄存器
- 处理模式
- 流水线
- MMU
- 指令集
- 中断
- FPU
- 总线架构
2、以STM32为例进行介绍
2.1 寄存器
| 寄存器 | 名称 | 作用 |
|---|---|---|
| R0-R3 | 通用寄存器 | 用于数据传递、计算及函数参数传递;R0 也用于存储函数返回值。 |
| R4-R12 | 通用寄存器 | 用于存储局部变量,减少频繁的内存访问。 |
| R13 | 栈指针 (SP) | 指向当前栈顶,负责管理栈操作。分为主栈指针 (MSP) 和 进程栈指针 (PSP):系统中断处理和普通任务可以使用不同的栈。栈指针用于管理栈的操作,包括函数调用时保存现场和中断处理时保存寄存器状态。 |
| R14 | 链接寄存器 (LR) | 保存函数调用返回的地址,函数返回时恢复程序执行。 |
| R15 | 程序计数器 (PC) | 指向当前执行的指令地址,控制程序执行的流程。 |
| xPSR | 程序状态寄存器 | 包含条件标志 (N, Z, C, V) 以及处理器状态 (T 位用于 Thumb 指令集)。 |
| CONTROL | 控制寄存器 | 控制处理器工作模式,如栈指针选择 (MSP/PSP) 和权限级别 (特权级/用户级)。 |
| PRIMASK | 中断屏蔽寄存器 | 屏蔽所有可屏蔽中断,保证关键代码段不被中断打断。 |
| BASEPRI | 基础优先级寄存器 | 设置中断优先级屏蔽阈值,低于该阈值的中断会被屏蔽。 |
| FAULTMASK | 故障屏蔽寄存器 | 屏蔽所有异常,包括硬件故障,通常用于系统恢复或严重故障时。 |
分类记忆:
通用寄存器:R0-R12
R0-R3:用于数据传递、计算及函数参数传递;R0 也用于存储函数返回值。
R4-R12:用于存储局部变量,减少频繁的内存访问。
特殊功能寄存器:
R13(栈指针 SP):指向当前栈顶,管理栈操作。
R14(链接寄存器 LR):保存函数调用返回地址。
R15(程序计数器 PC):指向当前执行的指令地址,控制程序流程。
状态和控制寄存器:
xPSR(程序状态寄存器):包含条件标志和处理器状态。
CONTROL(控制寄存器):控制处理器工作模式。
PRIMASK、BASEPRI、FAULTMASK:用于中断和故障管理。
2.2 处理模式
stm32默认普通程序和中断程序都工作在特权级。
- 处理者模式
- 始终运行在特权级
- 线程模式
- 可以运行在特权级和非特权级,通过CONTROL寄存器控制。
2.3 流水线
-
概念
MCU的流水线,指的是在指令执行过程中将一条指令的不同阶段拆分成多个步骤,让这些步骤可以并行执行,从而提高指令吞吐量。 -
一个典型的 ARM 处理器指令流水线包括以下阶段:
- 取指(Fetch):从内存中获取指令。
- 译码(Decode):将指令翻译成处理器可以理解的操作。
- 执行(Execute):执行指令,如加法、乘法、位移等操作。
- 存储(Memory Access):如果需要,进行内存访问,读取或写入数据。
-
ARM 处理器的流水线可以有多个阶段,常见的有 3 级、5 级或 7 级流水线,甚至更深的流水线设计。
2.4 MMU
MMU定义:Arm MMU深度解读
-
ARM 处理器中的 MMU(Memory Management Unit,内存管理单元) 用于支持虚拟内存和内存保护。
-
它通过将虚拟地址转换为物理地址,并设置内存访问权限,确保操作系统和应用程序的内存安全。MMU 是多任务操作系统(如 Linux)运行的关键。
- 虚拟内存:MMU 支持将程序的地址空间映射到物理内存中,使得不同的任务可以使用不同的虚拟地址空间。
- 内存保护:通过 MMU,操作系统可以保护内存空间,防止进程间非法访问。
-
对于一些低端 ARM Cortex-M 系列(如 Cortex-M0),没有内置 MMU,而是使用 MPU(Memory Protection Unit) 进行简单的内存保护,而不支持完整的虚拟内存。
2.5 指令集
ARM 处理器的指令集架构基于 RISC 设计原则,使用精简指令集。常见的 ARM 指令集架构有:
- ARM 指令集:用于标准 32 位指令集的 ARM 处理器,支持更复杂的运算和操作。
- Thumb 指令集:是 ARM 的一种压缩指令集,指令长度为 16 位,旨在减少内存占用,适用于资源受限的嵌入式系统。Thumb 指令集的执行效率虽然略低,但通过减少代码大小提高了存储效率。
- Thumb-2 指令集:结合了 32 位 ARM 指令和 16 位 Thumb 指令,使得处理器能够在运行时动态切换不同指令集,提供更高的性能和代码密度。
2.6 中断
ARM 处理器具有复杂的中断和异常处理机制,其中NVIC(Nested Vectored Interrupt Controller,嵌套向量中断控制器) 是 Cortex-M 系列中的重要模块,用于管理中断。
- 中断优先级:ARM Cortex-M 支持多级中断优先级,可以快速响应高优先级中断。
- 中断嵌套:允许高优先级中断在低优先级中断的处理中打断执行,实现中断的嵌套。
在发生中断时,处理器会自动保存必要的寄存器,并跳转到对应的中断服务程序 (ISR) 执行,处理完后恢复执行原程序。
中断现场保存
2.7 FPU
在一些高性能的 ARM Cortex-M 处理器(如 Cortex-M4、Cortex-M7)中,集成了硬件浮点运算单元 (FPU),用于加速浮点数的运算。这对于涉及大量数学计算的应用(如信号处理、图像处理)非常有用。
- 单精度浮点运算(FPU-S):支持 IEEE 754 标准的单精度浮点运算。
- 双精度浮点运算(FPU-D):更高端的处理器支持双精度浮点运算。
2.8 总线架构
冯·诺依曼结构,也称统一存储结构,ARM 处理器通过各种总线架构连接外设、存储器和其他模块,常见的总线架构包括:
- AHB (Advanced High-performance Bus):高性能总线,用于连接内存和高速外设。
- APB (Advanced Peripheral Bus):低速外设总线,用于连接定时器、串口、GPIO 等外设。
- AXI (Advanced eXtensible Interface):在高端 ARM 处理器中使用,支持高吞吐量和并发的外设访问。
回顾
- stm32有哪些通用寄存器
- stm32有哪些特殊功能寄存器
- stm32有哪些状态和控制寄存器
- 讲一下stm32的两种处理模式
- 为什么要用虚拟地址?为什么要用MMU?
- ARM常见的指令集架构有哪些
- 介绍一下NVIC
- 介绍一下stm32的总线架构
相关文章:
STM32八股【2】-----ARM架构
1、架构包含哪几部分内容 寄存器处理模式流水线MMU指令集中断FPU总线架构 2、以STM32为例进行介绍 2.1 寄存器 寄存器名称作用R0-R3通用寄存器用于数据传递、计算及函数参数传递;R0 也用于存储函数返回值。R4-R12通用寄存器用于存储局部变量,减少频繁…...
智能汽车图像及视频处理方案,支持视频智能包装能力
美摄科技的智能汽车图像及视频处理方案,通过深度学习算法与先进的色彩管理技术,能够自动调整图像中的亮度、对比度、饱和度等关键参数,确保在各种光线条件下,图像都能呈现出最接近人眼的自然色彩与细节层次。这不仅提升了驾驶者的…...
<C#> 详细介绍.net 三种依赖注入:AddTransient、AddScoped、AddSingleton 的区别
在 .NET 8 里,AddTransient、AddScoped 和 AddSingleton 均为依赖注入容器用于注册服务的方法,不过它们的生命周期管理方式存在差异。下面为你详细介绍这三种方法的区别。 1. AddTransient AddTransient 方法所注册的服务,每次被请求时都会…...
jenkins+1panel面板java运行环境自动化部署java项目
本文章不包含1panel面板安装、jenkins部署、jenkins连接git服务器等操作教程,如有需要可以抽空后期补上 jenkins安装插件Publish Over SSH 在系统配置添加服务器 查看项目的工作空间 项目Configure->构Post Steps选择Send files or execute commands over SSH…...
C语言 【实现电脑关机小游戏】非常好玩
引言 在时间限制内做出正确的回答,时间一到,电脑自动关机,听起来是不是很有意思,下面来看看怎么实现吧。 注意:该游戏只在windows系统下可以玩, 一、游戏原理: 在Windows系统下,通…...
备份比赛数据【算法赛】
0备份比赛数据【算法赛】 - 蓝桥云课 问题描述 蓝桥杯大赛的组委会最近遇到了一个棘手的问题。他们有 N 台电脑需要备份比赛数据,每台电脑所需的备份时间分别为 A1,A2,…,AN 分钟。 备份必须按编号顺序依次进行,即先第 1 台,再第 2 …...
[网络安全] 滥用Azure内置Contributor角色横向移动至Azure VM
本文来源于团队的超辉老师,其系统分析了Azure RBAC角色模型及其在权限滥用场景下的攻击路径。通过利用AADInternals工具提升用户至Contributor角色,攻击者可在Azure VM中远程执行命令,创建后门账户,实现横向移动。文中详述了攻击步…...
人工智能(AI)系统化学习路线
一、为什么需要系统化学习AI? 人工智能技术正在重塑各行各业,但许多初学者容易陷入误区: ❌ 盲目跟风:直接学习TensorFlow/PyTorch,忽视数学与算法基础。 ❌ 纸上谈兵:只看理论不写代码,无法解…...
Ubuntu系统使用nmcli配置静态IP
1. 配置静态IP 以下命令请全部加上sudo, 否则很可能会报错!!! 列出可用的网络连接 nmcli connection show找到你的 WiFi 连接名称(如 "WiFi名称")。 设置静态 IP 地址、网关和 DNS nmcli connection modif…...
vue3,element-plus 表格单选、多选、反选、全选
准备 定义数据 // 表格 const table ref(); // 表格数据 import type { User } from "/interface"; const tableData ref<User[]>([]); // 表格选集 const tableSelection ref<User[]>([]); // 表格选择行 const tableSelectedRow ref<User>…...
ngx_http_core_server_name
定义在 src\http\ngx_http_core_module.c static char * ngx_http_core_server_name(ngx_conf_t *cf, ngx_command_t *cmd, void *conf) {ngx_http_core_srv_conf_t *cscf conf;u_char ch;ngx_str_t *value;ngx_uint_t i;ngx_…...
如何提升库存系统的高并发和稳定性:算法与设计模式
库存系统是企业运营的核心模块,尤其是在电商、零售和供应链管理中,系统的高并发和稳定性直接影响订单处理的准确性和效率。面对海量订单、复杂的库存管理需求,如何在高并发环境下确保库存数据的准确性和系统的稳定性?本文将从架构…...
【Linux】从开发到系统管理深入理解环境变量
文章目录 前言一、环境变量概念1.1 为什么需要环境变量?1.2 环境变量的本质特征 二、环境变量PATH2.1 PATH的运作机制2.2 常见环境变量及其作用2.3 环境变量操作指南 三、再谈环境变量3.1main函数命令行参数解析3.2 环境变量的继承机制3.3 本地变量与内部构建命令 总…...
C++相关
1.定义pos时最好用无符号整型 如uint8_t size_t 编译器可能会有(有符号/无符号不匹配)的警告 总的来说就是符号一致 2.遇到俩个lambda相互调用的情况 使用std:funtion前置声明 3.回顾了虚函数,定义virtual 就是虚函数 一般是父类指针指向子…...
智算中心系统化建设与运营框架
智算中心系统化建设与运营框架 围绕智算中心全生命周期,从政策驱动到技术落地构建完整解决方案: 一、政策与产业生态 政策支撑体系 算力补贴机制: 国家层面:工信部“东数西算”工程对西部智算中心给予电价优惠(0.3元/…...
空气质量查询API:助力健康生活与环境监测的智能工具
引言 随着工业化和城市化的快速发展,空气质量问题日益受到人们的关注。空气质量不仅影响我们的日常生活,还直接关系到我们的健康。因此,了解空气质量指数(AQI)以及各项污染物的浓度,对于保障人们的健康至关…...
【CGE】社会核算矩阵构建(一):SAM基本结构
【CGE】社会核算矩阵构建(一):SAM基本结构 社会核算矩阵构建(一):SAM基本结构一、SAM的概念和基本特点二、SAM的基本结构1.开放经济体的SAM表结构2.SAM表各账户的主要核算内容(1)社会…...
Ubuntu 系统部署 Ollama + DeepSeek + Docker + Ragflow
🌹作者主页:青花锁 🌹简介:Java领域优质创作者🏆、Java微服务架构公号作者😄 🌹简历模板、学习资料、面试题库、技术互助 🌹文末获取联系方式 📝 Mysql数据库规范 一、Ol…...
深入探究 JVM 堆的垃圾回收机制(二)— 回收
GC Roots 枚举需要遍历整个应用程序的上下文,而在进行可达性分析或者垃圾回收时,如果我们还是进行全堆扫描及收集,那么会非常耗时。JVM 将堆分为新生代及老生代,它们的回收频率及算法不一样。 1 回收算法 在进行可达性分析时&am…...
第三讲 | C/C++内存管理完全手册
C/C内存管理 一、 C/C内存分布二、 C语言中动态内存管理方式:malloc/calloc/realloc/free三、 C内存管理方式1. new/delete操作内置类型2. new和delete操作自定义类型 四、operator new和operator delete函数(重点)五、new和delete的实现原理…...
2021年蓝桥杯第十二届CC++大学B组真题及代码
目录 1A:空间(填空5分_单位转换) 2B:卡片(填空5分_模拟) 3C:直线(填空10分_数学排序) 4D:货物摆放(填空10分_质因数) 5E…...
秒杀业务优化之从分布式锁到基于消息队列的异步秒杀
一、业务场景介绍 优惠券、门票等限时抢购常常出现在各类应用中,这样的业务一般为了引流宣传而降低利润,所以一旦出现问题将造成较大损失,那么在业务中就要求我们对这类型商品严格限时、限量、每位用户限一次、准确无误的创建订单,…...
IntelliJ IDEA 将 Spring Boot 项目远程部署到服务器
使用 IntelliJ IDEA 将 Spring Boot 项目远程部署到服务器的详细步骤,涵盖多种常见方法: 方法一:通过 SSH Maven 插件直接部署 1. 服务器环境准备 确保服务器已安装: Java 运行环境(与项目 JDK 版本一致࿰…...
Qt 重入和线程安全
重入和线程安全 在整个文档中,"重入"和 "线程安全 "这两个术语被用来标记类和函数,以表明它们在多线程应用程序中的使用方式: 线程安全函数可以同时被多个线程调用,即使调用使用的是共享数据,因…...
23种设计模式中的策略模式
在策略模式定义了一系列算法或策略,并将每个算法封装在独立的类中,使得它们可以互相替换。通过使用策略模式,可以在运行时根据需要选择不同的算法,而不需要修改客户端代码。 策略模式:Strategy。指的是,定义…...
纯vue手写流程组件
前言 网上有很多的vue的流程组件,但是本人不喜欢很多冗余的代码,喜欢动手敲代码;刚开始写的时候,确实没法下笔,最后一层一层剥离,总算实现了;大家可以参考我写的代码,可以拿过去定制…...
WPS宏开发手册——使用、工程、模块介绍
目录 系列文章前言1、开始1.1、宏编辑器使用步骤1.2、工程1.3、工程 系列文章 使用、工程、模块介绍 JSA语法 第三篇练习练习题,持续更新中… 前言 如果你是开发人员,那么wps宏开发对你来说手拿把切。反之还挺吃力,需要嘻嘻…...
面试中如何回答性能优化的问题
性能问题和Bug不同,后者的分析和解决思路更清晰,很多时候从应用日志(文中的应用指分布式服务下的单个节点)即可直接找到问题根源,而性能问题,其排查思路更为复杂一些。 对应用进行性能优化,是一个系统性的工程,对工程师的技术广度和技术深度都有所要求。一个简单的应用…...
django入门教程之request和reponse【二】
接上节:入门【一】 再创建一个orders子应用,python manager.py startapp orders,orders目录中新建一个urls.py文件。结构如图: 通过上节课,我们知道在views.py文件中编写函数时,有一个默认入参request&…...
解决 IntelliJ IDEA 方法断点导致程序无法运行的问题
前言 在日常开发中,调试是程序员不可或缺的工具之一。IntelliJ IDEA 作为一款功能强大的集成开发环境(IDE),提供了丰富的调试功能,例如设置断点、单步执行、变量监视等。然而,有时候我们在调试过程中会遇到…...
