1.10.ARM的编程模式和7种工作模式
2017-08-03 11:08
211 查看
ARM的基本设定:
* ARM采用的是32位架构
* ARM约定:
- Byte(字节):8bits
- Halfword(半字):16bits(2 Byte)
- Word(字):32bits(4 Byte)
* 大部分ARM core提供
- ARM指令集(32-bit)
- Thum
4000
b指令集(16-bit)
- Thumb2指令集(16&32 bit)
* Jazelle cores 提供 java bytecode
ARM处理器的7种工作模式:
- User:非特权模式,大部分任务执行在这种模式下。
- FIQ:(Fast interrupt Request 快速中断请求),当一个高优先级(fast)中断产生时将进入这种模式。
- IRQ:(interrupt request 中断请求),当一个低优先级(normal)中断产生时将进入这种模式。
- Supervisor:当复位或软中断指令执行时将进入这种模式。
- Abort:当存取异常时将进入这种模式。
- Undef:当执行未定义指令时将进入这种工作模式。
- System:使用和User模式相同指令集的特权模式。
注意:
* 除了User(用户模式)是 Normal(普通模式),其它6种都是Privilege(特权模式)。
* Privilege中除System模式外,其余5种为异常模式。
* 各种模式的切换,可以是程序员通过代码主动切换(通过写CSPR寄存器),也可以是CPU某些情况下自动切换。
* 各种模式下权限和可以访问的寄存器不同。
CPU为什么设计这些模式?
* CPU是硬件,OS是软件。软件的设计要依赖硬件的特性,硬件的设计要考虑软件的需求,便于实现软件特性。
* 操作系统有安全级别要求,因此CPU设计多种模式是为了方便操作系统的多种角色安全等级需要。
* ARM采用的是32位架构
* ARM约定:
- Byte(字节):8bits
- Halfword(半字):16bits(2 Byte)
- Word(字):32bits(4 Byte)
* 大部分ARM core提供
- ARM指令集(32-bit)
- Thum
4000
b指令集(16-bit)
- Thumb2指令集(16&32 bit)
* Jazelle cores 提供 java bytecode
ARM处理器的7种工作模式:
- User:非特权模式,大部分任务执行在这种模式下。
- FIQ:(Fast interrupt Request 快速中断请求),当一个高优先级(fast)中断产生时将进入这种模式。
- IRQ:(interrupt request 中断请求),当一个低优先级(normal)中断产生时将进入这种模式。
- Supervisor:当复位或软中断指令执行时将进入这种模式。
- Abort:当存取异常时将进入这种模式。
- Undef:当执行未定义指令时将进入这种工作模式。
- System:使用和User模式相同指令集的特权模式。
注意:
* 除了User(用户模式)是 Normal(普通模式),其它6种都是Privilege(特权模式)。
* Privilege中除System模式外,其余5种为异常模式。
* 各种模式的切换,可以是程序员通过代码主动切换(通过写CSPR寄存器),也可以是CPU某些情况下自动切换。
* 各种模式下权限和可以访问的寄存器不同。
CPU为什么设计这些模式?
* CPU是硬件,OS是软件。软件的设计要依赖硬件的特性,硬件的设计要考虑软件的需求,便于实现软件特性。
* 操作系统有安全级别要求,因此CPU设计多种模式是为了方便操作系统的多种角色安全等级需要。
相关文章推荐
- ARM的编程模式和7种工作模式
- ARM第一部分-ARM的编程模式和7种工作模式
- ARM寄存器的7种工作模式
- ARM内核寄存器 两种状态 7种工作模式
- [ARM] ARM处理器的7种工作模式和2种工作状态
- ARM的7种工作模式、37个通用寄存器、CPSR程序状态寄存器
- ARM寄存器的7种工作模式和几种寻址方式
- 1.2.12、ARM的编程模式和7种模式
- 12.ARM的编程模式和7中工作模式
- ARM编程模式和7种模式
- ARM处理器的7种工作模式--linux操作系统与ARM的工作模式
- 1_ARM的工作模式 7种工作模式
- ARM的2种状态和7种工作模式
- S5PV210系列(裸机二) ARM的编程模式、7种模式和37个寄存器
- ARM的编程模式和7种模式
- 下面哪种工作模式不属于ARM特权模式?
- ARM的工作模式和中断流程
- ARM工作模式简介
- 专题2-我从内部看ARM-ARM工作模式+寄存器详解
- arm 工作模式