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             //}
相关推荐
社会零时工11 小时前
机械臂末端2D相机自动对焦应用
arm开发·机器学习
陌上花开缓缓归以1 天前
W25N01KVZEIR flash烧写
arm开发
济6172 天前
ARM Linux 驱动开发篇----字符设备驱动开发(4)--- 编写chrdevbase 字符设备驱动开发实验--- Ubuntu20.04
linux·arm开发·驱动开发
代码游侠2 天前
学习笔记——I2C子系统
linux·arm开发·驱动开发·单片机·嵌入式硬件
陌上花开缓缓归以3 天前
mips架构uboot 启动流程分析
arm开发·架构
陌上花开缓缓归以3 天前
ddr专题分析
arm开发
电脑小白技术3 天前
arm架构能装windows吗?arm架构安装Windows两种方法
arm开发·windows·架构·arm架构能装windows吗
ONLYOFFICE3 天前
如何在 openSUSE 16 ARM 上安装 ONLYOFFICE 桌面编辑器
arm开发·编辑器
梁洪飞3 天前
uboot spl学习
linux·arm开发·嵌入式硬件·arm
戏舟的嵌入式开源笔记3 天前
Arm2D使用教程(四):借助片外Flash放置图片资源
arm开发·stm32·arm2d