嵌入式 ARM 开发入门解析

作为一名嵌入式开发者,理解底层硬件与指令集架构是写出高效代码的基础。今天就结合我整理的学习笔记,和大家聊聊 ARM 开发的核心知识点。

一、CPU 架构:CISC 与 RISC 的本质区别

计算机 CPU 内核主要分为两大阵营:

1、CISC(复杂指令集计算机)

代表架构:x86

特点:指令数量多、功能复杂,芯片面积大、功耗高,存在 "2/8 效应"(20% 的指令承担 80% 的工作)

适用场景:PC、服务器等对性能要求极高的领域

2、RISC(精简指令集计算机)

代表架构:ARM、MIPS、RISC-V

特点:指令数量少、格式统一,芯片面积小、功耗低、体积小巧

适用场景:手机、嵌入式设备、便携电子产品

ARM 就是典型的 RISC 架构,凭借低功耗优势,成为了嵌入式领域的绝对主流

二、Cortex

A: Application 应用, 手机、应用电子领域

R: real time 实时性 ,汽车电子 , 航空航天

M: Micro 微控制器 MCU 单片机领域

接下来要学习的imx6ull用的处理器内核则是 Cortex-A7,指令集版本为ARMv7-A(也常简称为 armv7)

三、Cortex-A7 内核寄存器详解

ALU:算术逻辑单元

R0 - R12 通用寄存器( 内核 ):存放数据

pc寄存器:program counter,程序计数器,本质上是一个指针,指向当前代码正在执行指令的下 一条指令

lr寄存器:linked register,链接寄存器,保存函数返回地址

sp寄存器 :stack pointer,栈指针寄存器 ,用来管理栈区

cpsr寄存器:current program status register, 当前程序状态寄存器 ,保存程序运行到某一步时的状态

spsr寄存器:save program status register,保存/备份程序状态寄存器异,异常发生时,保存cpsr寄存器中的程序状态

MMU:Mermory Manager Unit,内存管理单元用于管理虚拟内存到物理内存映射,从而提高物理 内存的利用率

Cache:高速数据缓存, 直接从Cache访问数据 ,提高CPU访问数据的效率

icache:instruction cache,指令缓存,用于指令

dcache: data cache,数据缓存, 用于数据

(所以ARM普遍使用哈佛架构)

在学习裸机时,必须要关闭MMU,打开 icache,关闭 dcache

四、存储类型与总线

  1. 存储器类型

RAM:易失性存储器,掉电数据丢失,读写速度快,用于程序运行时数据

ROM/Flash:非易失性存储器,掉电数据不丢失,用于存储程序和固件

Nor Flash:字节可寻址,适合存储代码

Nand Flash:块操作(通常 512 字节),容量大、成本低,适合存储数据

  1. 总线通信

单总线通信 :通过一根线 /一组线和外设通信,和某个外设通信时,其他外设接不进来

双总线通信 :

AHB总线: 先进高速总线 (USB、网卡 、RAM),连接通信速率快的外设

APB总线:先进外设总线 (GPIO、 UART),连接通信速率慢的外设

为了平衡不同外设的速度,ARM 采用双总线架构

五、程序编译

1、程序编译所经历的阶段

(1)预处理(Pre-Processing):处理和#号相关的代码,将C语言展开、替换、按照条件加入去除

(2)编译(Compiling):将C语言代码编译成汇编代码

(3)汇编(Assembling):将汇编代码编译为机器语言

(4)链接(Linking):将用户的代码与系统中的库链接成一个可执行程序

2、交叉编译:在一个平台编写编译程序,能够在另外 一个平台运行程序

六、异常向量表

本质是一个数组, 数组中存放的是跳转到对应异常服务函数的指令

七、处理器工作模式

八、ARM寄存器

ARM 有37个32-Bits长的寄存器

Cortex体系结构下有40个32-Bits长的寄存器

相关推荐
运维成长记43 分钟前
关于“有x86镜像,没有Dockerfile” 怎么制作arm架构的镜像
arm开发·架构
是星辰吖~6 小时前
X86反汇编:破茧成蝶 —— 赤裸逻辑与机械之心(1-1)
汇编
熠速8 小时前
PolarBox高性能实时仿真系统
arm开发·fpga开发·嵌入式实时数据库·硬件在环半实物仿真
逆向命运9 小时前
PC企微搜索手机号窗口绕过
c语言·汇编·c++·飞书·企业微信
天下·第二1 天前
如何在【x86】服务器上打包构建【arm】镜像
服务器·arm开发·eureka
是星辰吖~1 天前
函数战争:内存领地的争夺与撤退
汇编
止观止1 天前
在 WSL2 上从零搭建 ARM 混合编程环境
汇编·arm开发·嵌入式开发·混合编程
陌上花开缓缓归以2 天前
nand flash bbt和bmt管理
arm开发
十年编程老舅2 天前
读懂 MCU 启动:从上电到程序运行全链路
单片机·嵌入式硬件·mcu·嵌入式·cpu·嵌入式开发·ram
小熊officer2 天前
AMD架构与ARM架构
arm开发·架构