ARM工作模式

ARM

ARM架构

RAM:随机访问存储器

ROM:只读访问存储器

AHB:先进高速总线

APB:先进外设总线

USB:统一串行总线

norflash:可以被寻址

nandflash:不可以被寻址

ALU:算数逻辑单元

ARM七个工作模式

复制代码
user:  用户模式(USR):正常程序执行模式,不能直接切换到其他模式
system:系统模式(SYS):运行操作系统的特权任务,与用户模式类似,但具有可以直接切换到其他模式等特权
FIQ:   快中断模式(FIQ):支持高速数据传输及通道处理,FIQ异常响应时进入此模式
IRQ:   中断模式(IRQ):用于通用中断处理,IRQ异常响应时进入此模式
Supervisor:管理模式(SVC):操作系统保护模式,系统复位和软件中断响应时进入此模式(由系统调用执行软中断SWI命令触发)
Abort: 中止模式(ABT):用于支持虚拟内存和/或存储器保护,在ARM7TDMI没有大用处
Undef: 未定义模式(UND):支持硬件协处理器的软件仿真,未定义指令异常响应时进入此模式

寄存器

ARM微处理器共有37个32位寄存器,其中31个为通用寄存器,6个位状态寄存器。

Cortex有40个32位寄存器

r0 - r12:通用寄存器

r13 (sp):栈指针寄存器

r14(lr):链接寄存器

r15(pc):程序计数器:指向程序运行的下一行

cpsr:当前程序状态寄存器

spsr:备份程序状态寄存器

异常向量表

函数指针的数组

1.拷贝cpsr到spsr上

2.设置

3.保存返回地址到LR_

4.设置pc为相应的异常向量

返回时:

1.从spsr_恢复cpsr

2.从LR_恢复PC

复制代码
总结:恢复cpsr和pc

存储格式(内存大小端)

存储器格式:

大端格式:高字节在低地址,低字节在高地址

小端格式:高字节在高地址,低字节在低地址

汇编指令

1.基本框架

c 复制代码
	area reset, code, readonly
	code32
	entry           //{


	end             //}
相关推荐
咖喱年糕29 分钟前
KEIL5 编译错误解决:MDK 5.37 及以上版本添加 AC5(ARM Compiler 5)编译器
arm开发·单片机·keil·嵌入式软件·ac5
振南的单片机世界2 小时前
中央对齐PWM:边沿对齐EMI大,中央对齐更安静
arm开发·stm32·单片机·嵌入式硬件
三佛科技-187366133972 小时前
GD32F103VDT6是什么芯片?GD32 ARM Cortex-M3微控制器MCU解析
arm开发·单片机·嵌入式硬件
都在酒里3 小时前
【极致低延时】香橙派部署 MediaMTX 实现 WebRTC 推流,延时仅 500-800ms,比局域网 ffmpeg 拉流快近 10 倍!(附踩坑全记录)
linux·arm开发·ffmpeg·webrtc·orangepi·嵌入式软件
XINVRY-FPGA4 小时前
XC7A100T-2CSG324I AMD Xilinx Artix-7 FPGA
arm开发·人工智能·嵌入式硬件·神经网络·fpga开发·硬件工程·fpga
拼搏的小浣熊16 小时前
香橙派Zero3的奇幻之旅【【持续更新】香橙派zero3从入门到玩转 各种工具+笔记】
arm开发·物联网·香橙派
专注VB编程开发20年1 天前
tftp不支持列出目录下文件的功能
arm开发·tftp
cft56200_ln1 天前
TDA4时间同步3 网卡添加虚拟时间戳
c语言·开发语言·arm开发·驱动开发·嵌入式硬件·网络协议
振南的单片机世界2 天前
启动流程:上电先取栈顶和复位向量,再进main
arm开发·stm32·嵌入式硬件
振南的单片机世界4 天前
HAL_Delay(1000)真准吗?SysTick的1ms基准从哪来
arm开发·stm32·单片机·嵌入式硬件