ARM状态结构小记

在系统学习ARM寄存器结构和功能之前,有必要先了解一下ARM的工作模式和工作状态。

一、 ARM的工作状态

两种状态为:

  • ARM状态(32位)
  • Thumb状态(16位)

用BX Rn指令来进行两种状态的切换:
其中BX是跳转指令,Rn是寄存器,如果Rn的位0为1(最低位),则进入Thumb状态;如果Rn的位为0,这进入ARM状态。(ARM指令的后两位始终为0,没有被使用;而Thumb指令的后一位始终为0,没有被使用,因此采用位0来表示ARM指令与Thumb指令的切换标志位。)

例如下面两个指令就可以实现从ARM状态切换到Thumb状态,第一条指令将r6寄存器最低位置为1,接着 bx r6 就切换到了Thumb状态。

   ……
   0x00008cfc <+12>:    add r6, pc, #1
   0x00008d00 <+16>:    bx  r6
   0x00008d04 <+20>:    ...
   0x00008d06 <+22>:    ...
   0x00008d08 <+24>:    ...
   ……

注:ARM和Thumb两种状态之间的切换不影响处理器的工作模式和寄存器的内容;ARM处理器在处理异常时,不过处理器处于什么状态,则都将切换到ARM状态。


对于 ARM 指令来说,所有的指令长度都是 32 位,并且执行周期大多为单周期,指令都是有条件执行的。
而 Thumb 指令的特点如下:

  • 指令执行条件经常不回使用。
  • 源寄存器与目标寄存器经常是相同的。
  • 使用的寄存器数量比较少。
  • 常数的值比较小。
  • 内核中的桶式移动器(barrel shifter)经常是不使用的。

也就是说 16 位的 Thumb 指令一般可以完成 和 32 位 ARM 指令相同的任务。Thumb指令是ARM指令的子集,只要遵循一定的调用规则就可以互相调用。
Thumb指令与ARM指令的时间效率和空间效率关系为:

  • 存储空间约为ARM代码的60%~70%
  • 指令数比ARM代码多约30%~40%
  • 存储器为32位时ARM代码比Thumb代码快约40%
  • 存储器为16位时Thumb比ARM代码快约40~50%
  • 使用Thumb代码,存储器的功耗会降低约30%

二、 ARM的工作模式

七种工作模式为:

  • usr 用户模式:正常用户模式,程序正常执行模式
  • sys 系统模式:(基本上等同于usr)(System)运行特权操作系统任务
  • svc 特权模式:(Supervisor)也叫操作系统保护模式,处理软件中断swi reset
  • abt 中止模式:(Abort mode){数据、指令} 处理存储器故障、实现虚拟存储器和存储器保护
  • und 未定义指令模式:(Undefined)处理未定义的指令陷阱,支持硬件协处理器的软件仿真
  • irq 外部中断模式:处理普通中断
  • fiq 快速中断模式:(Fast Interrupt Request)处理快速中断,支持高速数据传送或通道处理

上述七种工作模式中,除了用户模式之外的其他6种处理器模式称为特权模式。

特权模式下,程序可以访问所有的系统资源,也可以任意地进行处理器模式的切换。

特权模式中,除系统模式外,其他5种模式又称为异常模式。

大多数的用户程序运行在用户模式下,此时,应用程序不能够访问一些受操作系统保护的系统资源,应用程序也不能直接进行处理器模式的切换。

用户模式下,当需要进行处理器模式切换时,应用程序可以产生异常处理,在异常处理中进行处理器模式的切换。

三、 关于状态和模式的切换

处理器模式可以通过软件进行切换,也可以通过外部中断或者异常处理过程进行切换。

当应用程序发生异常中断时,处理器进入相应的异常模式。在每一种异常模式下都有一组寄存器,供相应的异常处理程序使用,这样就可以保证在进入异常模式时,用户模式下的寄存器不被破坏。

系统模式并不是通过异常进入的,它和用户模式具有完全一样的寄存器。但是系统模式属于特权模式,可以访问所有的系统资源,也可以直接进行处理器模式切换。它主要供操作系统任务使用。通常操作系统的任务需要访问所有的系统资源,同时该任务仍然使用用户模式的寄存器组,而不是使用异常模式下相应的寄存器组,这样可以保证当异常中断发生时任务状态不被破坏。

Thumb指令低密度及窄存储器时性能高的特点使得其在大多数基于 C 代码的系统汇中有非常广泛的应用,但是有些场合中系统只能使用 ARM 指令,比如:

  1. 如果对于速度有比较高的要求,ARM指令在宽存储器中会提供更高的性能。
  2. 某些功能只能由 ARM 指令来实现,例如访问 CPSR 寄存器来使能/禁止 中断或改变处理器工作模式;访问协处理器CP15;执行 C 代码不支持的 DSP 算术指令;异常中断(Exception)处理。

另外,在进入异常中断后,内核会自动切换到 ARM 状态。即在异常中断处理程序人口的一些指令是ARM指令,然后根据需要,程序可以切换到 Thumb 工作状态,在异常中断处理程序返回前,程序在切换到 ARM 工作状态。

注:当处理器处于Thumb状态时发生异常(如irq、fiq、und、abt、svc等),则异常处理返回时,自动切换到Thumb状态。需要了解的是,ARM 处理器总是 从 ARM 工作状态开始执行的。因此,如果要在调试器重新运行 Thumb 程序,必须为 该 Thumb 程序添加一个 ARM程序头,然后再切换到Thumb工作状态调用该 Thumb程序。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,561评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,218评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,162评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,470评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,550评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,806评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,951评论 3 407
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,712评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,166评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,510评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,643评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,306评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,930评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,745评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,983评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,351评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,509评论 2 348

推荐阅读更多精彩内容