2022年2022年关于arm处理器remap的理解和实现

上传人:桔**** 文档编号:567325264 上传时间:2024-07-19 格式:PDF 页数:8 大小:328.10KB
返回 下载 相关 举报
2022年2022年关于arm处理器remap的理解和实现_第1页
第1页 / 共8页
2022年2022年关于arm处理器remap的理解和实现_第2页
第2页 / 共8页
2022年2022年关于arm处理器remap的理解和实现_第3页
第3页 / 共8页
2022年2022年关于arm处理器remap的理解和实现_第4页
第4页 / 共8页
2022年2022年关于arm处理器remap的理解和实现_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《2022年2022年关于arm处理器remap的理解和实现》由会员分享,可在线阅读,更多相关《2022年2022年关于arm处理器remap的理解和实现(8页珍藏版)》请在金锄头文库上搜索。

1、关于 arm 处理器 remap 的理解和实现2008 年 06 月 01 日 星期日11:51 0.我的理解是:在ROM 从 0x0 用几句指令引导系统之后,把RAM 映射到 0x0 就是 Remap 。1.Remap 的作用当 ARM 处理器上电或者Reset 之后,处理器从0x0 取指。因此,必须保证系统上电时,0x0 处有指令可以执行。所以,上电的时候,0x0 地址处必定是ROM 或者 Flash (NOR )。但是,为了加快启动的速度,也方便可以更改异常向量表,加快中断响应速度,往往把异常向量表映射到更快、更宽( 32bit/16bit )的 RAM 中。但是异常向量表的开始地址是由

2、ARM 架构决定的,必须位于0x0处,因此,必须把RAM 映射到 0x0 。2.Remap 的配置) 如果处理器有专门的寄存器可以完成Remap 。 那么 Remap 是通过 Remap 寄存器的相应bit 置 1 完成的。如 Atmel AT91xx )如果处理器没有专门的寄存器,但是memory 的 bank 控制寄存器可以用来配置bank 的起始地址,那么只要把 RAM 的起始地址编程为0x0 ,也可以完成remap 。如)如果上面两种机制都没有,那么Remap 就不要做了。因为处理器实现决定了SDRAM 对应的 bank 地址是不能改变的。如配置前后要做的工作前后,不同之处就是RAM

3、的位置变了。为了达到Remap 的目的,就是加快启动的速度和异常处理速度,一定要初始化异常堆栈和建立异常向量表的。4. 1)使用它的NAND boot模式。为什么NAND boot会比较快,那是因为2410 里面有块小石头 SteppingStone,一块 4KB SRAM ,它是映射在0x0 的。启动程序会自动被copy 到这个石头里面。自然异常向量的入口放到这个地方,一样可以达到比NOR boot 快的启动、异常响应速度。)如果你对 NOR Boot情有独衷,那么你只好把你的异常向量的入口copy 到 SDRAM 里面,实现所谓的High Vector 存储器地址重映射是当前很多先进控制器

4、所具有的功能。在上一节中已经提到了 0 地址处存储器重映射的例子,简而言之,地址重映射就是可以通过软件配置来改变一块存储器物理地址的一种机制或方法。当一段程序对运行自己的存储器进行重映射的时候,需要特别注意保证程序执行流程在重映射前后的承接关系。下面是一种典型的存储器地址重映射情况:名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 8 页 - - - - - - - - - 系统上电后的缺省状态是0 地址上放有ROM ,这块 ROM 有两个地址:从0 起始和从 0x1000

5、0 起始,里面存储了初始化代码。当进行地址remap 以后,从 0 起始的地址被定向到了RAM 上, ROM 则只保留有唯一的从0x10000 起始的地址了。如果存储在 ROM 里的 Reset_Handler 一直在 0 0x4000 的地址上运行,则当执行完 remap 以后,下面的指令将从RAM 里预取,必然会导致程序执行流程的中断。根据系统特点,可以用下面的办法来解决这个问题:(1) 上电后系统从0 地址开始自动执行,设计跳转指令在remap 发生前使PC 指针指向 0x10000 开始的 ROM 地址中去,因为不同地址指向的是同一块ROM ,所以程序能够顺利执行。(2) 这时候 0

6、- 0x4000 的地址空间空闲,不被程序引用,执行remap 后把 RAM 引进。因为程序一直在0x10000 起始的 ROM 空间里运行, remap 对运行流程没有任何影响。(3) 通过在 ROM 里运行的程序,对RAM 进行相应的代码和数据拷贝,完成应用程序运行的初始化。下面是一段实现上述步骤的例程:ENTRY ;启动时,从0 开始,设法跳转到 真 的 ROM 地址( 0x10000 开始的空间里)LDR pc, =start ;insert vector table here Start ;Begin of Reset_Handler ; 进行 remap 设置LDR r1, =Ct

7、rl_reg ;假定控制 remap 的寄存器LDR r0, r1 ORR r0, r0, #Remap_bit ;假定对控制寄存器进行remap 设置STR r0, r1 ;接下去可以进行从ROM 到 RAM 的代码和数据拷贝名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 8 页 - - - - - - - - - 除此之外,还有另外一种常见的remap 方式,如下图:原来 RAM 和 ROM 各有自己的地址,进行重映射以后RAM 和 ROM 的地址都发生了变化,这种情

8、况下,可以采用以下的方案:(1) 上电后,从0 地址的 ROM 开始往下执行。(2) 根据映射前的地址,对RAM 进行必要的代码和数据拷贝。(3) 拷贝完成后,进行remap 操作。(4) 因为 RAM 在 remap 前准备好了内容,使得PC 指针能继续在RAM 里取到正确的指令。不同的系统可能会有多种灵活的remap 方案,根据上面提到的两个例子,可以总结出最根本的考虑是:要使程序指针在remap 以后能继续往下得到正确的指令。实例分析:基于S3C4510B系统的启动流程及REMAP1 S3C4510B简介S3C4510B ,基于以太网,16/32 位 RISC 微处理器。芯片部集成了8K

9、B 的 Cache/SRAM和 Ethernet 控制器,片外可扩展ROM 、Flash 、SDRAM 等存储芯片。S3C4510B 芯片内部没有程序存储器,所有程序都被存储在片外扩展的ROM 和 Flash 中。开始启动时,存有启动代码的ROM 或 Flash 将被映射为0x00 地址,系统从此开始运行。但在实际应用中,为提高系统的实时性,加快代码的执行速度,系统启动后程序往往要被搬移到RAM 中,因为 RAM 的存取速度要比ROM 快得多, 这样大大提升系统的性能。由于 S3C4510B芯片中的异常中断入口地址被固定在0x00 开始的 8 个字中,系统只能将地址空间重新分配,把RAM 映射

10、到 0x00 地址处,这正是Remap 的原因所在。S3C4510B 内部有几个特殊寄存器,用于实现地址空间和芯片内外存储介质的映射。这几个寄存器的简介如下:SYSCFG :设置特殊寄存器的起始地址和片内SRAM 的起始地址。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 8 页 - - - - - - - - - EXTDBWTH :设置各 Bank 寄存器所映射芯片的数据线宽度。ROMCON0 ROMCON5 :设置系统内片扩展ROM 和 Flash 的起始和终止地址

11、。DRAMCON0 DRAMCON3 :设置系统内片外扩展RAM 的起始和终止地址。S3C4510B 芯片内特殊寄存器段的物理地址为0x3ff0000 ,各特殊寄存器的偏移地址详见S3C4510B的技术手册。2S3C4510B系统中 Remap 的实现地址空间的重新分配,与处理器的硬件结构紧密相关。总体来说,32 位系统中的地址重映射机制可以分为两种情况:一类是处理器内部专门的寄存器可以完成Remap ,这样只需将Remap 寄存器的相应位置1,由硬件逻辑来完成地址的重新映射,如AtmelAT91xx系列;另一类没有专门的Remap 控制寄存器,需要重新改写处理器内部用于控制Memory 起止

12、地址的 Bank 寄存器,来实现Remap 过程。 S3C4510B属于第二种情况。2.1 硬件系统结构及地址分配假设系统是以Samsung 公司给出的测试板为参考建立的,其中ROM 的容量为 512KB ,8 位数据总线,Remap 前的地址范围为0x0000000 0x0100000,Remap后的地址范围为0x1000000 0x1100000 ; RAM的容量为 16MB ,32 位数据总线, Remap 前的地址范围为0x0100000 0x100000,Remap后的地址范围为 0x0000000 0x1000000 ;Flash 的容量为 2MB ,16 位数据总线, Remap

13、 前后地址不变,均为0x1100000 0x1300000 。Remap 前后的地址映射关系如图2 所示。2.2 系统启动过程及Remap 实现系统的地址重映射应该在系统的启动中完成,以下是S3C4510B 的 Remap 启动过程。系统特殊寄存器的设置。主要是配置如上所述的用于实现地址空间和芯片内外存储介质映射的寄存器,在本系统中配置如下:SYSCFG=0x87ffff90 EXTDBWTH=0x3001 ROMCON0=0x01000060 ROMCON1=0x13044060 DRAMCON0=0x11004060 初始化系统堆栈。在ARM7 的体系结构中共有七种工作模式,不同的模式有不

14、同堆栈指针,互不干扰。各模式对应于不同异常中断,至于哪些模式的堆栈需要初始化取决于用户使用了哪些中断,以及系统需要处理些异常类型。一般来说,管理者(SVC )堆栈必须设置,如果使用了IRQ 中断,则 IRQ 堆栈也必须设置。有一点需要注意的是,为保证Remap 后程序运行正常,所有堆栈应设置在RAM 的高端地址中。初始化 I/O 口、UART 、定时器、中断控制器以及系统中所用到的其它资源。在初始化异常向量表或修改异常向量表中的入口地址前,要关掉所有中断。异常向量表的初始化。将民常中煌怛处理程序的入口地址写入RAM 中相应的异常向量。必须保证的是,异常向量表绝对不会被从ROM 搬移到 RAM

15、中的代码和数据所覆盖,为此,异常向量表一般被定义在RAM 中的高端地址中。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 8 页 - - - - - - - - - 程序代码及数据的搬移。Remap 后, RAM 被映射到 0x0000 的地址空间, ROM 则被移到高端地址上。为保证 Remap 后程序能够瞠运行,ROM 中的代码和数据必须地址不变地被移到RAM 中。这是 Remap成功的关键。两种途径可以实现搬移。一种是不管实际的代码空间有多大,直接将 ROM 地址空

16、间整个搬移到RAM 中。当然,这种方法并不适合在真正的启动代码中使用,但在做初步的Remap 测试时,可以用来检验堆栈及异常中断的设置是否合理。另一种方法较复杂,它使用了SDT 链接器 ARMLink 产生的定位信息,仅把RO 风吹草动的有效代码和数据段到 RAM 中。ARMLink 将编译后的程序链接成ELF 文件。 映像文件内部共有三种输出段:RO 段、RW段和 ZI 段。这三种输出段分别包含了只读代码及包含在代码段中的少量数据、可读写的数据、初始化为0的数据, ARMLink 同时还产生了这三种输出段的起始和终止定位信息:Image$RO$Base、Image$RO$Limit、Imag

17、e$RW$Base、Image$Limit 、Image$Linit和 Image$ZI$Limit。可以在程序中使用这些定位信息。将ROM 中的代码和数据搬移到RAM 中,其实现代码如下:数据定义:BaseOfROMDCD|Image$RO$Base| TopOfROMDCD|Image$RO$Limit| BaseOfBSSDCD|Image$RW$Base| BaseOfZeroDCD|Image$ZI$Base| EndOfBSSDCD|Image$ZI$Limit| 源程序:;将 ROM 中的程序搬移到RAM 中,重映射后的地址不变adrr0,ResetEntry;ROM中程序起始地

18、址movr3,#(RamBaseAddr16);RamBaseAddr=0x100 Idrr1,BaseOfROM Idrr2,TopOfROM Addr1,r1,r3 Addr2,r2,r3 0 Idmiar0!,r4-r11 Stmiar1!,r4-r11 Cmpr1,r2 Bcc%B0 ;将 RW 段中预初始化的变量搬移到RAM 中subr1,r1,r2 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 8 页 - - - - - - - - - subr0,r0,r

19、1; 将 r0 指向 RO 段的结束,即RW 段的开始ldrr1,BaseOfBSS Idrr2,BaseOfZero Addr1,r1,3 Addr2,r2,r3 1;基于局部标号的相对跳转,PC+偏移地址,产生与位置无关的代码cmpr1,r2 ldrccr4,r0,#4 strccr4,r1 ,#4 bcc%B1 ;接着把 ZI 段搬移到 RAM 中,并其将初始化为0 movr0,#0 Idrr2,EndOfBSS Addr2,r2,r3 2 cmpr1,2 strccr0,r1,#4 bcc%B2 地址的重新映射。 S3C4510B中的 Remap 过程其实很简单, 只需重新设置ROMC

20、ON0 ROMCON5和DRAMCON0 DRAMCON3 。在本系统中只需重新设置ROMCON0和 DRAMCON0 。源代码:;/*内存控制寄存器重新设置-存储空间重新映射地址空间*/ EXPORTRemapMemory RemapMemory movr12,r14 adrr0,RemapMem ldmiar0,r1-r11 ldrr0,=ROMCON0;ROMCON0为 Bank 寄存器的起始地址stmiar0,r1-r11 blExceptionTalbeInit;中断向量表重新初始化名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - -

21、- - - 名师精心整理 - - - - - - - 第 6 页,共 8 页 - - - - - - - - - movpc,r12 RemapMem DCD&11040060;/*ROMCON00x10000000x1100000*/ DCD&10000398 ;/*DRACON00x0 0x1000000*/ 进入 C 代码空间,开始主程序的运行。此时代码应该运行于RAM 中。上面的步骤可以根据实际需要进行适当的添加或删节。值得注意的是:汇编生成的代码应该是与位置无关的代码,即代码在运行期间可以被映射到不同的地址空间,其中的跳转指令都是基于PC 寄存器的相对跳转指令。基于PC 的标号是位于

22、目标指令前或者程序中数据定义伪操作前的标号,这种符号在汇编时将被处理成 PC 值加上或减去一个数字常量。3 异常中断的处理在 Remap 的启动代码中,需要特别注意的是异常中断的处理。在S3C4510B中,异常中断的入口地址是固定的,按表1 次序排列。表 1 异常类型工作模式正常地址复位 管理0x00000000 未定义指令未定义0x00000004 软件中断(SWI ) 管理 0x00000008 预取中止中止0x0000000 数据中止中止 0x00000010 预留 - 0x00000014 IRQ(中断)IRQ 0x00000018 FIQ(快速中断)FIQ 0x0000001 地址重

23、新映射之后,入口地址被映射到RAM 中,中断处理代码也被搬移到RAM 地址空是。此时,中断响应和中断处理的速度都将大大加快,这将有利于提高整个系统的实时性。异常中断向量表的设计结构如图3 所示。下面是各部分的源代码(以IRQ 异常中断为例)。异常向量表的定义:(系统初始化时,将异常处理代码入口地址写入异常中的向量表)_RAM_END_ADDREQU0x01000000;重映射后 RAM 的终止地址MAP (_RAM_END_ADDR-0x100)SYS_RST_VECTOR#4 UDF_INS_VECTOR#4 SWI_SVC_VECTOR#4 INS_ABT_VECTOR#4 DAT_ABT

24、_VECTOR#4 RESERVED_VECTOR#4 IRQ_SVC_VECTOR#4 FIQ_SVC_VECTOR#4 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 8 页 - - - - - - - - - 异常初始化代码:bIRQ_SVC_HANDLER;0x18 IRQ_SVC_HANDLER SUBsp,sp,#4 ;满递减堆栈STMFDsp!,r0 LDRr0,=IRQ_SVC_VECTOR;读取中断向量,;IRQ_SVC_VECTOR=SystemrqH

25、andle LDRr0,r0 STRr0,sp,#4 LDMFDsp!,r0,pc;跳转到异常中断处理代码入口异常处理入口代码:SystemIrqHandler IMPORTISR_IrqHandler STMFDsp!,r0-r12,lr BLISR_IrqHandler;跳转到 C 代码中异常中断处理程序ISR_IrqHandler LDMFDsp!,r0-r12,lr SUBSpc,lr,#4 在如上的结构中,不管系统是否进行了地址的重映射,异常中断向量都可以在运行时动态改变,大大提高了中断处理中的灵活性。中断向量可以在运行时指向不同的异常处理代码入口。?2010 Baidu http:/ 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 8 页,共 8 页 - - - - - - - - -

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号