嵌入式软件与设计 学习笔记总结-ARM 技术补充

3.1* ARM处理器工作状态

ARM状态:32位,进入ARM状态:操作数寄存器Rm的状态为bit[0]为0时,执行“BX Rm”指令进入。

Thumb状态:16位,进入Thumb状态:操作数寄存器Rm的状态为bit[0]为1时,执行“BX Rm”指令进入。

程序执行中,处理器可在两种状态下切换

两种状态的切换不影响处理器的模式或寄存器的内容

ARM处理器在开始执行代码时,只能处于ARM状态

3.2* ARM处理器工作模式

用户模式:不能由异常进入

FIQ模式:处理快速中断,FIQ异常响应时进入此模式

IRQ模式:处理普通中断,IRQ异常响应时进入此模式

SVC模式:管理,操作系统保护模式,处理软件中断SWI,系统复位软件中断响应时进入此模式

中止模式(abt):处理存储器故障,实现虚拟存储器和存储器保护,指令预取中止数据访问中止响应时进入此模式

未定义模式(und):处理未定义的指令陷阱,支持硬件协处理器的软件仿真

系统模式:不能由异常进入,运行特权操作系统任务,与用户模式类似,但可以自由切换处理器模式

用户模式是非特权模式,其他六种是特权模式

特权模式主要处理异常和监控调用(软件中断),可以自由访问系统资源和切换模式

特权模式除系统模式外,其他五种称为异常模式,用于处理中断和异常

3.3* ARM寄存器组成

如图所示,ARM寄存器分为31个通用寄存器和6个状态寄存器

带三角的寄存器为影子寄存器,它们是处理器在不同工作模式下特有的我物理寄存器。异常模式下,它们将代替用户模式或系统模式下使用的部分寄存器。

3.4* ARM的异常中断

指令执行引起的直接异常:软件中断、未定义指令、预取指中止

指令执行引起的间接异常:数据中止(读取、存储数据时存储器故障)

外部产生的与指令流无关的异常:复位、IRQ、FIQ

3.5* ARM存储器数据类型和存储格式

数据类型

字节型数据Byte:数据宽度为8位

半字数据类型HalfWord:数据宽度为16位,存取必须以2字节对齐的方式

字数据类型Word

存储方式:根据最低有效字节和相邻较高字节相比,存在在较高还是较低地址

小端格式:较高的有效字节放在较高的存储器地址,较低的有效字节放在较低的存储器地址

大端格式:较高的有效字节放在较低的存储器地址,较低的有效字节放在较高的存储器地址

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值