ARM裸机-8

1、ARM的编程模式和工作模式

1.1、ARM的基本设定

        ARM采用的是32位架构

        ARM约定:

                - Byte:8 bits

                - Halfword :16 bits (2 byte)

                - Word:32 bits (4 byte)

        大部分ARM core 提供:

                - ARM 指令集 (32-bit)

                - Thumb 指令集 (16-bit )

                - Thumb2指令集(16 &32bit)
        Jazelle cores 支持 Java bytecode

1.2、ARM处理器工作模式

ARM 有7个基本工作模式:

        User:非特权模式,大部分任务执行在这种模式。

        FIQ:当一个高优先级(fast) 中断产生时将会进入这种模式。

        RQ:当一个低优先级 (noral) 中断产生时将会进入这种模式。

        Supervisor:当复位或软中断指令执行时将会进入这种模式。

        Abort::当存取异常时将会进入这种模式。

        Undef:当执行未定义指令时会进入这种模式。

        System:使用和User模式相同寄存器集的特权模式。

注意:

        除User (用户模式) 是Normal (普通模式)外,其他6种都是Privilege (特权模式)。

        Privilege中除Sys模式外,其余5种为异常模式。

        各种模式的切换,可以是程序员通过代码主动切换 (通过写CPSR寄存器);也可以是CPU在某些情况下自动切换。

        各种模式下权限和可以访问的寄存器不同。

1.3、CPU为什么设计这些模式

        CPU是硬件,OS是软件,软件的设计要依赖硬件的特性,硬件的设计要考虑软件需要,便于实现软件特性。

        操作系统有安全级别要求,因此CPU设计多种模式是为了方便操作系统的多种角色安全等级需要。

2、ARM的37个寄存器

 

(1)ARM总共有37个寄存器,但是每种模式下最多只能看到18个寄存器,其他寄存器虽然名字相同但是在当前模式不可见。

(2)对r14这个名字来说,在ARM中共有6个名叫r14(又叫lr)的存器,但是在每种特定处理器模式下,只有一个r14是当前可见的,其他的r14必须切换到他的对应模式下才能看到。这种设计叫影子寄存器 (banked register)。

(3)System模式使用user模式寄存器集

总结:

        ARM共有37个寄存器,都是32位长度。

        37个寄存器中30个为“通用”型,1个固定用作PC,一个固定用作CPSR,5个固定用作5种异常模式下的SPSR。

PC (r15) 程序控制寄存器
        PC (Program control register) 为程序指针,PC指向哪里,CPU就会执行哪条指令(所以程序跳转时就是把目标地址代码放到PC中),整个CPU中只有一个PC (CPSR也只有一个,但SPSR有5个)。

3、ARM的异常处理方式简单介绍

3.1、什么是异常

        正常工作之外的流程都叫异常。

        异常会打断正在执行的工作,并且一般我们希望异常处理完成后继续回来执行原来的工作。

        中断是异常的一种。

3.2、异常向量表

        所有的CPU都有异常向量表,这是CPU设计时就设定好的,是硬件决定的。

        当异常发生时,CPU会自动动作 (PC跳转到异常向量处处理异常,有时伴有一些辅助动作)。

        异常向量表是硬件向软件提供的处理异常的支持。

3.3、ARM的异常处理机制

        当异常产生时,ARM core:

                - 拷贝 CPSR到SPSR_<mode>

                - 设置适当的 CPSR位:
                        改变处理器状态进入 ARM 态

                        改变处理器模式进入相应的异常模式

                        设置中断禁止位禁止相应中断(如果需要)

                - 保存返回地址到 LR _<mode>

                - 设置 PC 为相应的异常向量

        返回时,异常处理需要:

                -从SPSR_<mode>恢复CPSR

                - 从LR_<mode>恢复PC

                - Note:这些操作只能在 ARM 态执行

3.4、总结

        异常处理中有一些是硬件自动做的,有一些是程序员需要自己做的。需要搞清楚哪些是需要自己做的,才知道如何写代码。

        以上说的是CPU设计时提供的异常向量表,一般称为一级向量表。有些CPU为了支持多个中断,还会提供二级中断向量表,处理思路类似于这里说的一级中断向量表。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值