s3c2410中文资料手册:2.1概述:有第1章,第2章,第十六章,第五章,第六章.
S3C2410A采用了非常先进的ARM920T内核,它是由ARM(Advanced RISC Machines)公司研制的。
2.2处理工作状态
从程序员的角度上看,ARM920T可以工作在下面两种工作状态下的一种:
ARM状态:执行32位字对齐的ARM指令;
THUMB状态:执行16位半字对齐的THUMB指令。在这种状态下,PC寄存器的第1位来选择一个字中的哪个半字。
注意:这两种状态的转换不影响处理模式和寄存器的内容。
2.3切换状态
进入Thumb状态
进入Thumb状态,可以通过执行BX指令,同时将操作数寄存器的状态位(0位)置1来实现。
当从异常(IRQ,FIQ,UNDEF,ABORT,SWI等)返回时,只要进入异常处理前处理器处于Thumb状态,也会自动进入Thumb状态。
进入ARM状态
进入ARM状态,可以通过执行BX指令,并且操作数寄存器的状态位(0位)清零来实现。
当处理进入异常(IRQ,FIQ,RESET,UNDEF,ABORT,SWI等)。这时,PC值保持在异常模式下的link寄存器中,并从异常向量地址处开始执行处理程序。
存储空间的格式
ARM920将存储器空间视为从0开始由字节组成的线性集合,字节0到3中保存了第一个字节,字节4到7中保存第二个字,依此类推,ARM920T对存储的字,可以按照小端 (Little endian)或大端(Big endian)的方式对待。在ARM状态下,任何时刻都可以看到16个通用寄存器,1或2个状态寄存器。在特权模式(非用户模式)下会切换到具体模式下的寄存器组,其中包括模式专用的私有(banked)寄存器。图2-3显示了在每个模式下哪种寄存器是可见的:私有寄存器上都有一个黑三角标记。
ARM状态寄存器系列中含有16个 直接操作寄存器:R0到R15。除了R15外其他的都是通用寄存器,可用来存放地址或数据值。除此之外,实际上有17个寄存器用来存放状态信息。具体说明如下:
寄存器14:专职持有返回点的地址,在系统执行一条“跳转并链接(link)”(BL)指令的时候,R14将收到一个R15的拷贝。其他的时候,它可以用作一个通用寄存器。相应的它在其他模式下的私有寄存器R14_svc,R14_irq,R14_fiq,R14_abt和R14_und都同样用来保存在中断或异常发生时,或时在中断和异常中执行了BL指令时,R15的返回值。
寄存器15是程序计数器(PC)。在ARM状态下,R15的bits[1:0]为0,bits[31:2]保存了PC的值。在Thumb状态下,bits[0]为0同时bits[31:1]保存了PC值。
寄存器16是CPSR(当前程序状态寄存器),用来保存当前代码标志和当前处理器模式位。
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
全部0条评论
快来发表一下你的评论吧 !