S3C2440体系架构[通俗易懂]

S3C2440体系架构[通俗易懂]本文是对ARM处理器架构的学习,针对S3C2440型号。参考了Samsung官方的技术文档S3C2440.pdf中的PROGRAMMER’SMODEL一节的内容。ARM和THUMB指令模式S3C2440采用了armv4t指令集,同时支持arm指令集和thumb指令集。arm指令是32位的,而thumb指令是16位的。之所以存在thumb指令是为了降低代码的存储空间。两个指令集之间的切换手动切换

大家好,又见面了,我是你们的朋友全栈君。

本文是对ARM处理器架构的学习,针对S3C2440型号。参考了Samsung官方的技术文档S3C2440.pdf中的PROGRAMMER’S MODEL一节的内容。

ARM和THUMB指令模式

S3C2440采用了armv4t指令集,同时支持arm指令集和thumb指令集。arm指令是32位的,而thumb指令是16位的。之所以存在thumb指令是为了降低代码的存储空间。

两个指令集之间的切换

  • 手动切换
    因为不管是arm指令集还是thumb指令集,代码地址的最低位都是多余的,因为thumb是16位对齐的,arm是32位对齐的。所以最后一位可以用来作为切换的参考。当执行BX指令时,若地址的最后一位置位,则接下来的指令使用thumb指令集来解释,跳转时,最后一位清零,则使用arm指令集。

  • 自动切换
    在特权模式下只能使用arm指令集,所以当在用户模式下执行thumb指令时,若跳转到特权模式时,将会自动切换到arm指令模式。当从特权模式切换回用户模式时,如果进入之前是thumb指令集,那么就是自动切换回thumb指令集。

数据存储格式
S3C2440同时支持大小端数据存储格式,默认情况下采用小端格式储存。

  • 大端储存
    高字节存储在低地址中,低字节存储在高地址中。

  • 小端存储
    高字节存储在高地址中,低字节存储在低地址中。

操作模式

ARM920T支持七种操作模式:

  • 用户模式

  • 快中断模式

  • 中断模式

  • 管理者模式

  • 中止模式

  • 系统模式

  • 未定义模式

模式转换可以通过软件的形式,也可以自动进行切换,比如产生了中断。除了用户模式,其它模式都是特权模式,有些资源只能在特权模式下使用。

寄存器

ARM920T总共有37个寄存器,同一时间不是所以的寄存器都是可见的。

ARM模式下的寄存器

ARM模式下的寄存器

thumb模式下的寄存器

在thumb模式下,不是所有的寄存器都是被使用的,R8-R12寄存器没有被使用。

thumb模式下的寄存器

虽然thumb模式下按规定R8-R12寄存器不能被使用,但是编译器能够使用这些寄存器作为快速存储。

状态寄存器

CPSR和SPSR是ARM920T中的两个状态寄存器,SPSR是用来临时保存CPSR寄存器的值的。

状态寄存器的作用

  • 保存最近ALU计算信息

  • 控制中断的开启和关闭

  • 设置处理器的模式

状态寄存器

异常处理

在ARM中,所有打断程序正常执行的事件都称为异常,中断也是属于异常。在进入异常的时候,硬件会自动执行如下的操作;但是当退出异常时,下列的操作是由我们自己编写软件实现的。

进入异常

1.保留下一个指令地址到合适的LR寄存器(哪种异常发生就将其保存在该模式下的LR寄存器中)。

2.复制CPSR到合适的SPSR中(哪种异常发生就将其保存在该模式下的SPSR寄存器中)。

3.设置CPSR中的模式位

4.PC从相应中断向量表中获取地址

退出异常

1.将LR中的值减去一个偏移量赋给PC

2.将SPSR的值拷贝到CPSR中

3.如果在进入时设置了中断禁止标志,清除禁止标志

举例说明:

HandleIRQ:
    sub lr, lr, #4 @ 计算返回地址
    stmdb   sp!,    { r0-r12,lr }   @ 保存使用到的寄存器
                                    @ 注意,此时的sp是中断模式的sp
                                    @ 初始值是上面设置的3072

    ldr lr, =int_return             @ 设置调用ISR即EINT_Handle函数后的返回地址  
    ldr pc, =EINT_Handle            @ 调用中断服务函数,在interrupt.cint_return:
    ldmia   sp!,    { r0-r12,pc }^  @ 中断返回, ^表示将spsr的值复制到cpsr

在中断处理函数EINT_Handle中需要将中断挂起位给清除掉。

下表是在退出各种异常时需要执行的返回函数:

异常退出执行代码

中断向量表地址

下表是中断向量表的地址,这些地址是规定好的,不能自己更改。

中断向量表

异常优先级

当多个异常同时发生时,有一个固定的优先级来决定哪一个先被执行。

高优先级

1. Reset
2. Data abort 
3. FIQ
4. IRQ
5. Prefetch abort

低优先级

6. Undefined Instruction,Software interrupt
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131367.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 香农编码的matlab仿真实现实验报告_香农编码例题

    香农编码的matlab仿真实现实验报告_香农编码例题实验目的:通过该实验,掌握通过计算机实验可变长信源编码方法,进一步熟悉香农编码,费诺编码以及霍夫曼编码方法。实验环境:Matlab7.1实验内容及过程:1.对于给定的信源的概率分布,用MATLAB语言实现香农编码。2.对于给定的信源的概率分布,用MATLAB语言实现霍夫曼编码。3.对于给定的信源的概率分布,用MATLAB语言实现游程编码。以下为M文件:1.funct…

    2025年9月8日
    9
  • mysql行转列转换

    mysql行转列转换mysql行列转换,在项目中应用的极其频繁,尤其是一些金融项目里的报表。其中最为头痛的就是多行转多列,动态的列行转换。最近在研究这些行里转换,还是从最为简单的行列转换开始。sql脚本–创建表学生表CREATETABLE`student`(`stuid`VARCHAR(16)NOTNULLCOMMENT’学号’,`stunm`VARCHAR(20

    2022年6月14日
    49
  • 每天一道算法_3_487-3279_对电话号码格式化统计批处理

    早上弄了一道求高精度幂的算法,偷懒用了内部类,总觉得过意不去,所以今天重新做了一道算法题,做完心里舒服好多。题目如下: Description企业喜欢用容易被记住的电话号码。让电话号码容易被记住的一个办法是将它写成一个容易记住的单词或者短语。例如,你需要给滑铁卢大学打电话时,可以拨打TUT-GLOP。有时,只将电话号码中部分数字拼写成单词。当你晚上回到酒店,可以通过拨打310-GI

    2022年3月10日
    363
  • batch内负采样

    batch内负采样一般在计算softmax交叉熵时,需要用tf.nn.log_uniform_candidate_sampler多itemid做随机负采样。但是在类似dssm这种双塔模型中,item侧特征除了itemid外,还有其他meta特征,此时负样本对itemid做负采样后,还需要取相应负样本的meta特征。可是在tf训练数据中并不方便建立itemid与各类meta特征的映射表。为了解决dssm类模型的负采样问题,可以取一个batch内其他用户的正样本做为本用户的负样本,以解决负采样meta特征问题。好了,废话少说,

    2022年6月23日
    72
  • Redis Desktop Manager的下载及安装,免费

    Redis Desktop Manager的下载及安装,免费1.下载链接百度云盘提取密码:wt462.安装教程傻瓜式安装,,点下一步即可3.连接服务器hosts必填,名字自己起一个个性点的就行,密码需要看你服务器有没有密码

    2022年10月20日
    2
  • MySQL的锁机制和加锁原理

    MySQL的锁机制和加锁原理MySQL的锁机制和加锁原理文章目录MySQL的锁机制和加锁原理1.行锁2.表锁3.页锁4.乐观锁和悲观锁4.1悲观锁4.2乐观锁5.MySQL/InnoDB中的行锁和表锁问题5.1InnoDB锁的特性6.RecordLock、GapLock、Next-keyLock锁6.1.RecordLock6.2.GapLock6.2.​1什么叫间隙锁6.2.2为什么说gap锁是RR隔离级别…

    2022年6月5日
    38

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号