转自:http://blog.csdn.net/jobsss/article/details/7548550

版权声明:本文为博主原创文章,未经博主允许不得转载。

ARM 处理器有二十七个寄存器,其中一些是在一定条件下使用的,所以一次只能使用十六个...

寄存器 0 到寄存器 7 是通用寄存器并可以用做任何目的。不象 80x86 处理器那样要求特定寄存器被用做栈访问,或者象 6502 那样把数学计算的结果放置到一个累加器中,ARM 处理器在寄存器使用上是高度灵活的。
寄存器 8 到 12 是通用寄存器,但是在切换到 FIQ 模式的时候,使用它们的影子(shadow)寄存器。 
寄存器 13 典型的用做 OS 栈指针,但可被用做一个通用寄存器。这是一个操作系统问题,不是一个处理器问题,所以如果你不使用栈,只要你以后恢复它,你可以在你的代码中自由的占用(corrupt)它。每个处理器模式都有这个寄存器的影子寄存器。
寄存器 14 专职持有返回点的地址以便于写子例程。当你执行带连接的分支的时候,把返回地址存储到 R14 中。同样在程序第一次运行的时候,把退出地址保存在 R14 中。R14 的所有实例必须被保存到其他寄存器中(不是实际上有效)或一个栈中。这个寄存器在各个处理器模式下都有影子寄存器。一旦已经保存了连接地址,这个寄存器就可以用做通用寄存器了。
寄存器 15 是程序计数器。它除了持有指示程序当前使用的地址的二十六位数之外,还持有处理器的状态。 
为更清晰一些... 提供下列图表:

User 模式  SVC 模式   IRQ 模式   FIQ 模式  APCS

R0 ------- R0 ------- R0 ------- R0        a1
R1 ------- R1 ------- R1 ------- R1        a2
R2 ------- R2 ------- R2 ------- R2        a3
R3 ------- R3 ------- R3 ------- R3        a4
R4 ------- R4 ------- R4 ------- R4        v1
R5 ------- R5 ------- R5 ------- R5        v2
R6 ------- R6 ------- R6 ------- R6        v3
R7 ------- R7 ------- R7 ------- R7        v4
R8 ------- R8 ------- R8         R8_fiq    v5
R9 ------- R9 ------- R9         R9_fiq    v6
R10 ------ R10 ------ R10        R10_fiq   sl
R11 ------ R11 ------ R11        R11_fiq   fp
R12 ------ R12 ------ R12        R12_fiq   ip
R13        R13_svc    R13_irq    R13_fiq   sp
R14        R14_svc    R14_irq    R14_fiq   lr
------------- R15 / PC -------------       pc

最右侧的列是 APCS 代码使用的名字,关于 APCS 的详情参见这里。  
程序计数器构造如下:

位   31  30  29  28  27  26  25------------2  1  0

N   Z   C   V   I   F    程 序 计 数 器  S1 S0

对 R15 的详细解释,请参见 psr.html。 
下面是你想知道的"模式",比如上面提及的"FIQ"模式。

用户模式,运行应用程序的普通模式。限制你的内存访问并且你不能直接读取硬件设备。 
超级用户模式(SVC 模式),主要用于 SWI(软件中断)和 OS(操作系统)。这个模式有额外的特权,允许你进一步控制计算机。例如,你必须进入超级用户模式来读取一个插件(podule)。这不能在用户模式下完成。
中断模式(IRQ 模式),用来处理发起中断的外设。这个模式也是有特权的。导致 IRQ 的设备有键盘、 VSync (在发生屏幕刷新的时候)、IOC 定时器、串行口、硬盘、软盘、等等...
快速中断模式(FIQ 模式),用来处理发起快速中断的外设。这个模式是有特权的。导致 FIQ 的设备有处理数据的软盘,串行端口(比如在 82C71x 机器上的 A5000) 和 Econet。
IRQ 和 FIQ 之间的区别是对于 FIQ 你必须尽快处理你事情并离开这个模式。IRQ 可以被 FIQ 所中断但 IRQ 不能中断 FIQ。为了使 FIQ 更快,所以有更多的影子寄存器。FIQ 不能调用 SWI。FIQ 还必须禁用中断。如果一个 FIQ 例程必须重新启用中断,则它太慢了并应该是 IRQ 而不是 FIQ。

转载于:https://www.cnblogs.com/sky-heaven/p/5567448.html

什么是SVC模式【转】相关推荐

  1. u-boot分析(四)---设置异常向量表|设置SVC模式

    u-boot分析(四) 通过前三篇的分析,我们对u-boot已经有了整体的认识和掌握,但是我们仍然对于其部分硬件是如何初始化的不太清楚,所以接下来几篇博文我将会对我们在http://www.cnblo ...

  2. ARM(IMX6U)裸机C语言版本LED驱动实验(汇编进入处理器SVC模式、SP堆内存、跳转main函数、链接起始地址)

    参考:Linux之ARM(IMX6U)裸机C语言LED驱动实验–驱动编写,编译 作者:一只青木呀 发布时间: 2020-08-11 11:20:17 网址:https://blog.csdn.net/ ...

  3. arm 模式 Linux,ARM Linux:usr模式转为svc模式的实现原理

    大家都知道linux的应用程序要想访问内核必须使用系统调用从而实现从usr模式转到svc模式.下面咱们看看它的实现过程. 系统调用是os操作系统提供的服务,用户程序通过各种系统调用,来引用内核提供的各 ...

  4. 2. 内核解压-关中断进入svc模式

    内核解压的代码在arch/arm/boot/compressed/head.S start:.type start,#function.rept 7__nop.endr #ifndef CONFIG_ ...

  5. 【嵌入式开发】ARM 处理器工作模式 及 修改方法 ( 处理器模式 | 设置处理器模式 | 程序状态字寄存器 CPSR SPSR | 模式设置代码编写 | 设置 svc 模式 )

    一. 处理器工作模式相关介绍 1. 处理器模式简介 (1) 处理器工作模式分类 (2) 处理器不同工作模式区别 (3) Linux 系统运行的模式 (4) 特权模式 说明 (5) 异常模式 (6) 系 ...

  6. 【Android 逆向】ARM CPU 架构体系 ( ARM 处理器工作模式 | ARM 架构模型 )

    文章目录 一.ARM 处理器工作模式 二.ARM 架构模型 一.ARM 处理器工作模式 参考 [嵌入式开发]ARM 处理器工作模式 及 修改方法 ( 处理器模式 | 设置处理器模式 | 程序状态字寄存 ...

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

    作者 : 韩曙亮 博客地址 : http://blog.csdn.net/shulianghan/article/details/42375701 相关资源下载 :  -- 三星 ARM Archit ...

  8. Cortex-A7 MPCore 架构详细介绍(九种运行模式、内核寄存器组R0~R15,有特定的名字和功能)

    目录 0.ARM架构的历史简介 1.Cortex-A7 MPCore(即多核) 简介 2.Cortex-A 处理器九种运行模式 3.Cortex-A 寄存器组(内核寄存器) 3.1通用寄存器 3.1. ...

  9. ARM的7种工作模式、37个通用寄存器、CPSR程序状态寄存器

    一.ARM 采用的是32位架构 1.ARM约定 Byte:8 bits Halfword:16 bits (2 byte) Word:32 bits (4 byte) 2.大部分ARM core 提供 ...

最新文章

  1. python的源代码文件的扩展名是-python源文件后缀是什么?
  2. Linux之压缩与解压缩
  3. B1013 数素数(20分)
  4. 斯特芬森迭代法(Python)
  5. WINCE串口通讯经验小结
  6. if语句 power query_PowerQuery学习:认识M函数
  7. Linux useradd命令
  8. Label显示多行文本总结
  9. Codeforces Gym 100463A Crossings 逆序数
  10. python 路径拼接字符串_anaconda环境变量添加 python笔记
  11. 49.邮件模板的传值与调用
  12. speedoffice(Word)文字怎么添加下划线
  13. python列表如何求增长率_python如何计算环比增长率
  14. 对标TJA1043 SIT1043 带唤醒及故障保护的低功耗CAN FD总线收发器
  15. ios9企业证书提示“未受信任的企业级开发者”解决方法
  16. 四和能聚分析做直播带货的商家通常发布什么类型的短视频
  17. 计算机辅助医疗未来展望,数字骨科应用与展望:更精确、个性、直观的未来前景...
  18. 基于java jsp的社区志愿者服务系统
  19. H.264码流的分析
  20. 梅捷主板去掉启动自检_持续交付–第五部分–启动–自检

热门文章

  1. Pytorch模型迁移和迁移学习,导入部分模型参数
  2. Spring Data Redis入门示例:基于RedisTemplate (三)
  3. 我的学习之路_第十六章_xml
  4. 如何实现手游app瘦身?
  5. swf获取当前页面的路径
  6. javascript(js)获取访客通过搜索引擎进入页面的搜索关键词的简洁有效代码
  7. 大数高精运算-----乘法
  8. sqlserver 事务日志已满和'PRIMARY'
  9. JVM内存区域(运行时数据区)划分
  10. javascript 对象的设计模式