ARM之工作模式

前言

           以下内容是个人学习之后的感悟,转载请注明出处~

ARM工作模式

ARM工作模式根据功能不同,可分为7类:

  • User Mode:用户模式。操作系统的Task一般以这种模式执行。User Mode是ARM唯一的非特权模式,这表示如

果CPU处于这种模式下,很多指令将不能够执行,因此操作系统的资源得以保护。

  • System Mode:这是V4及其以上版本所引入的特权模式。
  • IRQ Mode:中断模式。中断(不包括软中断)处理函数在这种模式下执行。
  • FIQ Mode:快速中断模式。除了多了几个寄存器外,其他同IRQ一样。
  • Supervisor Mode:监视模式。软中断(SWI)处理函数在这种模式下执行。
  • Abort Mode:所有同内存保护相关的异常均在这种模式下执行。
  • Undefined Mode:处理无效指令的异常处理函数在这种模式下执行。

ARM工作模式也可分为3大类:

  • 用户模式:User Mode
  • 系统模式:System Mode
  • 异常模式:所有其它5种模式

  为什么可以把7类功能不同的模式分为3大类呢?

  这是由于异常模式同用户模式和系统模式有一个不一样的地方,那就是,当CPU产生中断或异常而自动切换到相应

异常模式后,CPU会根据产生中断或异常的原因执行相应得中断或异常向量。这些向量的位置是CPU事先定义好的,目

前有两种选择: 
    (1)   处于内存低地址0x00000000~0x0000001c,这种情况被称之为Low vector

(2)   处于内存高低之0Xffff0000~0xffff001c,这种情况被称之为High vector。

一般的操作系统会在这些异常向量地址处放置一条跳转指令。至于到底是使用Low vector,还是使用High vector,由

CPU自己决定,ARM规范不做任何限制。

  程序可以通过读取CPSR的MODE域来判断CPU当前的执行模式。

  如何看待ARM的各种模式?要回答这个问题,我们要看不同模式下,有哪些东西不同。归纳来说,有如下两个方面的不同:

(1) 物理寄存器不同 
     (2) 权限不同

  如果将User Mode作为参考模式,那么: 
      (1) System Mode:寄存器一样,仅仅是权限不同 
      (2) 其他Exception Mode:寄存器不一样,权限也不一样

  从权限的角度看,System Mode和其他Exception Mode(FIQ,IRQ,Supervisor,Abort,Undefined)是一样的,

他们之间的区别仅仅是寄存器方面有一些差别。

  从寄存器角度看,我们可以将CPSR中的MODE域看作一个类似于片选的东西,当其值不一样,所选中的寄存器也不一样。

虽然指令中的寄存器是一样的,但是经过MODE域的片选后,实际就指向不同的物理寄存器了。

  必须要特别注意,SYSTEM模式和USER模式除了权限不一样外,其他都一样,这样可以让操作系统自由访问16个寄存器

(包括状态寄存器)。

  那么,模式切换是如何进行的呢?

(1) 执行SWI或Reset指令。如果在User模式下执行SWI指令,CPU就进入Supervisor模式。当然,在其它模式下执行SWI

指令,也会进入Supervisor模式,补过一般操作系统不会这么做。因为除了User模式是非特权模式下,其他模式都属于特权模式

(这说明ARM只有两种执行态,不想Dummy的X86,定义了4种执行态)。执行SWI一般是为了访问系统资源,在特权模式下可

以访问所有的系统资源。SWI指令一般用来用来为操作系统提供API接口。

(2) 有外部中断发生。如果发生了外部中断,CPU就会进入IRQ或FIQ模式,具体是哪种模式,得看外部的中断源是接到CPU

的那个Pin。

(3)  CPU执行过程中产生异常。最典型的异常是由于MMU保护所引起的内存访问异常,此时CPU会切换到Abort模式。如果

是无效指令,则会进入Undefined模式。

  从上面我们发现,有一种模式是CPU无法自动进入的,这种模式就是System模式。要进入System模式必须由程序员自己编写指

令来实现。其实很简单,在任何特权模式下改变CPSR的MODE域为System模式所对应得数字即可。进入System模式一般是为了利

用“System 模式”和“User 模式”下的寄存器是一样的。因此一般操作系统在通过SWI进入Supervisor模式后,做一些简单处理后,

就进入System模式。

  另外,在任何特权模式下,都可以通过修改CPSR的MODE域而进入其他模式。不过需要注意的是,由于修改的CPSR是该模式下的

影子CPSR,因此并不是实际的CPSR,所以一般的做法是修改影子CPSR,然后执行一个MOVS指令来恢复执行到某个断点并切换到新模式。 

存储器格式(字对齐)

  Arm体系结构将存储器看做是从零地址开始的字节的线性组合。从零字节到三字节放置第一个存储的字(32位)数据,从第四个字

节到第七个字节放置第二个存储的字数据,一次排列。作为32位的微处理器,arm体系结构所支持的最大寻址空间为4GB。

  存储器格式:

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

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

  指令长度:

  Arm微处理器的指令长度是32位的,也可以为16位(thumb状态下)。Arm微处理器中支持字节(8位),半字(16位),字(32位)

三种数据类型,其中,字需要4字节对齐,半字需要2字节对齐。

  注:所谓的指令长度是一条完整的指令的长度,而不是单纯的mov这3个字母长度。

ARM体系的CPU有两种工作状态

   1、ARM状态:处理器执行32位的字对齐的ARM指令;

2、Thumb状态:处理器执行16位的、半字对齐的Thumb指令;

  在程序运行的过程中,可以在两种状态之间进行相应的转换。处理器工作状态的转变并不影响处理器的工作模式和相应寄存器中的

内容。CPU上电处于ARM状态。

寄存器

  ARM有31个通用的32位寄存器,6个程序状态寄存器,共分为7组,有些寄存器是所有工作模式共用的,还有一些寄存器专属于每

一种工作模式:

  R13——栈指针寄存器,用于保存堆栈指针;

  R14——程序连接寄存器,当执行BL子程序调用指令时,R14中得到R15的备份,而当发生中断或异常时,R14保存R15的返回值;

  R15——程序计数器;

  快速中断模式有7个备份寄存器R8—R14,这使得进入快速中断模式执行很大部分程序时,甚至不需要保存任何寄存器;

  其它特权模式都含有两个独立的寄存器副本R13、R14,这样可以令每个模式都拥有自己的堆栈指针和连接寄存器。

当前程序状态寄存器(CPSR)

  CPSR中各位意义如下:

  T位:1——CPU处于Thumb状态, 0——CPU处于ARM状态;

  I、F(中断禁止位): 1——禁止中断, 0——中断使能;

  工作模式位:可以改变这些位,进行模式切换。

以上是全部内容,如果有什么地方不对,请在下面留言,谢谢~

时间: 2024-10-05 14:00:01

ARM之工作模式的相关文章

ARM处理器工作模式

++++++++++++++++++++++++++++++++++++++++++ 本文转载自mr_raptor的专栏,感谢mr_raptor大神. http://blog.csdn.net/mr_raptor/article/details/6556157 ++++++++++++++++++++++++++++++++++++++++++ 1.1 ARM处理器工作模式 CPU的模式可以简单的理解为当前CPU的工作状态,比如:当前操作系统正在执行用户程序,那么当前CPU工作在用户模式,这时网

[国嵌笔记][021-022][ARM处理器工作模式]

[ARM处理器工作模式] 处理器工作模式 1.User(urs):用户模式,linux应用程序运行在用户模式 2.FIQ(fiq):快速中断模式 3.IRQ(irq):中断模式 4.Supervisor(svc):系统保护模式,linux内核运行在系统保护模式 5.Abort(abt):异常模式 6.Undefined(und):未定义指令模式 7.System(sys):系统模式 [ARM寄存器详解] ARM寄存器(37个) 通用寄存器(31个) 1.未分组通用寄存器(R0-R7) 2.分组通

2.2 ARM处理器工作模式

ARM Architecture Reference Manual Arm 指令框架手册 1. 处理器7种工作模式 Processor mode Mode number Description User usr 0b10000 Normal program execution mode FIQ fiq 0b10001 Supports a high-speed data transfer or channel process Supervisor svc 0b10011 A protected

【嵌入式开发】ARM 芯片简介 (ARM芯片类型 | ARM处理器工作模式 | ARM 寄存器 | ARM 寻址)

作者 : 韩曙亮 博客地址 : http://blog.csdn.net/shulianghan/article/details/42375701 相关资源下载 :  -- 三星 ARM Architecture Reference Manual 文档 : http://download.csdn.net/detail/han1202012/8324641 一. ARM 芯片类型 1. ARM 分类 (1) ARM 分类类型(芯片 | 核 | 指令架构) ARM 分类 : -- ARM 芯片类型

嵌入式中 ARM的几种工作模式 以及异常模式的优先级

一.Arm工作模式: Arm微处理器支持7种工作模式,分别为: 1. 用户模式(Usr)            用于正常执行程序 2. 快速中断模式(FIQ)    用于高速数据传输 3. 外部中断模式(IRQ)   用于通常的中断处理 4. 管理模式(SVC)          操作系统使用的保护模式(高权限),复位和软件中断进入 5. 数据访问终止模式(abt)   当数据或指令预取终止时进入该模式,可用于虚拟内存及存储保护 6. 系统模式(sys)            运行均有特权的操作

ARM工作模式

ARM工作模式 一.存储器格式(字对齐): Arm体系结构将存储器看做是从零地址开始的字节的线性组合.从零字节到三字节放置第一个存储的字(32位)数据,从第四个字节到第七个字节放置第二个存储的字数据,一次排列.作为32位的微处理器,arm体系结构所支持的最大寻址空间为4GB. 存储器格式 1.大端格式:高字节在低地址,低字节在高地址: 2.小端格式:高字节在高地址,低字节在低地址: 指令长度: Arm微处理器的指令长度是32位的,也可以为16位(thumb状态下).Arm微处理器中支持字节(8位

Arm的几种工作模式

ARM处理器工作模式一共有 7 种 : 1.USR 模式正常用户模式,程序正常执行模式 2.FIQ模式(Fast Interrupt Request)处理快速中断,支持高速数据传送或通道处理 3.IRQ模式处理普通中断 4.SVC模式(Supervisor)操作系统保护模式,处理软件中断swi reset 5.ABT 中止(Abort mode){数据.指令}处理存储器故障.实现虚拟存储器和存储器保护 6.UND 未定义(Undefined)处理未定义的指令陷阱,支持硬件协处理器的软件仿真 7.

ARM的编程模式

ARM的编程模式 Linux ARM的工作状态 (主要指指令模式) 基本概述 32位架构 指令相关 ARM 32bit Thumb指令 16bit Thumb-2 16||32 bit 兼容 复位后开始执行代码为ARM模式,ARM与Thumb通过BL指令切换16bit 存储格式 小端模式 低位低地址 ARM的工作模式 原文地址:https://www.cnblogs.com/Howbin/p/10661086.html

7.ARM处理器的工作模式

7.ARM处理器的工作模式 ARM七种工作模式:图1-1: 图1-1 上面的七种工作模式可以在cpsr设置:如下的M[4:0]=Mode number. 图1-2 之所以要有这么多种模式,是为了避免致命的错误.例如我们写的应用程序运行在User模式,操作系统的运作在比较高的模式. User模式:普通程序运行的模式. FIQ:快速中断运行的模式 RIQ:普通中断运行的模式 Supervisor:特权模式 Abort:访问内存异常等 Undefined:未定义模式,数据未定义. System:系统模