地址重映射在S3C4510B系统中的实现.docx

上传人:人*** 文档编号:550927248 上传时间:2023-05-09 格式:DOCX 页数:14 大小:17.50KB
返回 下载 相关 举报
地址重映射在S3C4510B系统中的实现.docx_第1页
第1页 / 共14页
地址重映射在S3C4510B系统中的实现.docx_第2页
第2页 / 共14页
地址重映射在S3C4510B系统中的实现.docx_第3页
第3页 / 共14页
地址重映射在S3C4510B系统中的实现.docx_第4页
第4页 / 共14页
地址重映射在S3C4510B系统中的实现.docx_第5页
第5页 / 共14页
点击查看更多>>
资源描述

《地址重映射在S3C4510B系统中的实现.docx》由会员分享,可在线阅读,更多相关《地址重映射在S3C4510B系统中的实现.docx(14页珍藏版)》请在金锄头文库上搜索。

1、地址重映射在S3C4510B系统中的实现摘要:介绍基于S3C4510B系统的启动流程;详细介绍Remap的实现过程及部分关键代码,给出启动代码中异常中断向量的处理。关键词:Remap 地址重映射 S3C4510B 异常中断近年来,随着32位芯片制造技术的不断完善,制造成本不断降低,国内的32位MCU市场也开始火爆起来。越来越多的工程师开始将开发目光从8位转移到32位微处理器上,基于32位MCU的产品如雨后春笋般层出不穷,应用领域涵盖了掌上设备、家用电器、网络设备、无线通信、工业控制等。在32位微控制芯片领域,ARM架构的芯片占了近70%的市场。本文中所用到的处理器正是Samsung公司生产的基

2、于ARM架构的S3C4510B。1 S3C4510B简介S3C4510B是一款基于以太网系统的高性价比、高性能的16/32位RISC微处理器。芯片部集成了8KB的Cache/SRAM和Ethernet控制器,减少了整个系统的成本。片外可扩展ROM、Flash、SDRAM等存储芯片,可以移植Clinux等复杂的操作系统。利用操作系统完善的TCP/IP协议栈充分发挥芯片的网络功能。S3C4510B芯片内部没有程序存储器,所有程序都被存储在片外扩展的ROM和Flash中。开始启动时,存有启动代码的ROM或Flash将被映射为0x00地址,系统从此开始运行。但在实际应用中,为提高系统的实时性,加快代码

3、的执行速度,系统启动后程序往往要被搬移到RAM中,因为RAM的存取速度要比ROM快得多,这样大大提升系统的性能。由于S3C4510B芯片中的异常中断入口地址被固定在0x00开始的8个字中,系统只能将地址空间重新分配,把RAM映射到0x00地址处,这正是Remap的原因所在。S3C4510B内部有几个特殊寄存器,用于实现地址空间和芯片内外存储介质的映射。这几个寄存器的简介SYSCFG:设置特殊寄存器的起始地址和片内SRAM的起始地址。EXTDBWTH:设置各Bank寄存器所映射芯片的数据线宽度。ROMCON0ROMCON5:设置系统内片扩展ROM和Flash的起始和终止地址。DRAMCON0DR

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

5、。S3C4510B属于第二种情况。 硬件系统结构及地址分配 为例于对地址重映射的过程进行分析,图1给出了本人用于测试的基本S3C4510B的系统硬件结构。文中给出的所有流程及代码都经过了测试。此系统是以Samsung公司给出的测试板为参考建立的,其中ROM的容量为512KB,8位数据总线,Remap前的地址范围为0x00000000x0100000,Remap后的地址范围为0x10000000x1100000;RAM的容量为16MB,32位数据总线,Remap前的地址范围为0x01000000x100000,Remap后的地址范围为0x00000000x1000000;Flash的容量为2MB

6、,16位数据总线,Remap前后地址不变,均为0x11000000x1300000。Remap前后的地址映射关系如图2所示。 系统启动过程及Remap实现 系统的地址重映射应该在系统的启动中完成,以下是S3C4510B的Remap启动过程。系统特殊寄存器的设置。主要是配置如上所述的用于实现地址空间和芯片内外存储介质映射的寄存器,在本系统中配置SYSCFG=0x87ffff90EXTDBWTH=0x3001ROMCON0=0x01000060ROMCON1=0x13044060DRAMCON0=0x11004060初始化系统堆栈。在ARM7的体系结构中共有七种工作模式,不同的模式有不贩堆栈指针,

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

8、义在RAM中的高端地址中。 程序代码及数据的搬移。Remap后,RAM被映射到0x0000的地址空间,ROM则被移到高端地址上。为保证Remap后程序能够瞠运行,ROM中的代码和数据必须地址不变地被移到RAM中。这是Remap成功的关键。两种途径可以实现搬移。一种是不管实际的代码空间有多大,直接将ROM地址空间整个搬移到RAM中。当然,这种方法并不适合在真正的启动代码中使用,但在做初步的Remap测试时,可以用来检验堆栈及异常中断的设置是否合理。另一种方法较复杂,它使用了SDT链接器ARMLink产生的定位信息,仅把RO风吹草动的有效代码和数据段到RAM中。ARMLink将编译后的程序链接成E

9、LF文件。映像文件内部共有三种输出段:RO段、RW段和ZI段。这三种输出段分别包含了只读代码及包含在代码段中的少量数据、可读写的数据、初始化为0的数据,ARMLink同时还产生了这三种输出段的起始和终止定位信息:Image$RO$Base、Image$RO$Limit、Image$RW$Base、Image$Limit、Image$Linit和Image$ZI$Limit。可以在程序中使用这些定位信息。将ROM中的代码和数据搬移到RAM中,其实现代码数据定义BaseOfROM DCD |Image$RO$Base|TopOfROM DCD |Image$RO$Limit|BaseOfBSS D

10、CD |Image$RW$Base|BaseOfZero DCD |Image$ZI$Base|EndOfBSS DCD |Image$ZI$Limit|源程序;将ROM中的程序搬移到RAM中,重映射后的地址不变adr r0,ResetEntry ;ROM中程序起始地址mov r3,#(RamBaseAddr16) ;RamBaseAddr=0x100Idr r1,BaseOfROMIdr r2,TopOfROMAdd r1,r1,r3Add r2,r2,r30Idmia r0!,r4-r11Stmia r1!,r4-r11Cmp r1,r2Bcc%B0;将RW段中预初始化的变量搬移到RAM中

11、sub r1,r1,r2sub r0,r0,r1 ;将r0指向RO段的结束,即RW段的开始ldr r1,BaseOfBSSIdr r2,BaseOfZeroAdd r1,r1,3Add r2,r2,r31 ;基于局部标号的相对跳转,PC+偏移地址,产生与位置无关的代码cmp r1,r2ldrcc r4,r0,#4strcc r4,r1,#4bcc %B1;接着把ZI段搬移到RAM中,并其将初始化为0mov r0,#0Idr r2,EndOfBSSAdd r2,r2,r32cmp r1,2strcc r0,r1,#4bcc%B2地址的重新映射。S3C4510B中的Remap过程其实很简单,只需重

12、新设置ROMCON0ROMCON5和DRAMCON0DRAMCON3。在本系统中只需重新设置ROMCON0和DRAMCON0。源代码;/*内存控制寄存器重新设置-存储空间重新映射地址空间*/EXPORT RemapMemoryRemapMemorymov r12,r14adr r0,RemapMemldmia r0,r1-r11ldr r0,=ROMCON0 ;ROMCON0为Bank寄存器的起始地址stmia r0,r1-r11bl ExceptionTalbeInit ;中断向量表重新初始化mov pc,r12RemapMemDCD &11040060 ;/*ROMCON0 0x10000

13、000x1100000*/DCD &10000398 ;/*DRACON0 0x00x1000000*/进入C代码空间,开始主程序的运行。此时代码应该运行于RAM中。 上面的步骤可以根据实际需要进行适当的添加或删节。值得注意的是:汇编生成的代码应该是与位置无关的代码,即代码在运行期间可以被映射到不同的地址空间,其中的跳转指令都是基于PC寄存器的相对跳转指令。基于PC的标号是位于目标指令前或者程序中数据定义伪操作前的标号,这种符号在汇编时将被处理成PC值加上或减去一个数字常量。 3 异常中断的处理在Remap的启动代码中,需要特别注意的是异常中断的处理。在S3C4510B中,异常中断的入口地址是

14、固定的,按表1次序排列。表1异常类型工作模式正常地址复位管理0x00000000未定义指令未定义0x00000004软件中断管理0x00000008预取中止中止0x0000000数据中止中止0x00000010预留-0x00000014IRQIRQ0x00000018FIQFIQ0x0000001地址重新映射之后,入口地址被映射到RAM中,中断处理代码也被搬移到RAM地址空是。此时,中断响应和中断处理的速度都将大大加快,这将有利于提高整个系统的实时性。异常中断向量表的设计结构如图3所示。下面是各部分的源代码。异常向量表的定义:_RAM_END_ADDR EQU 0x01000000 ;重映射后

15、RAM的终止地址MAPSYS_RST_VECTOR # 4UDF_INS_VECTOR # 4SWI_SVC_VECTOR # 4INS_ABT_VECTOR # 4DAT_ABT_VECTOR # 4RESERVED_VECTOR # 4IRQ_SVC_VECTOR # 4FIQ_SVC_VECTOR # 4异常初始化代码b IRQ_SVC_HANDLER ;0x18IRQ_SVC_HANDLERSUB sp,sp,#4 ;满递减堆栈STMFD sp!,r0LDR r0,=IRQ_SVC_VECTOR ;读取中断向量,;IRQ_SVC_VECTOR=SystemrqHandleLDR r0,r0STR r0,sp,#4LDMFD sp!,r0,pc;跳转到异常中断处理代码入口异常处理入口代码SystemIrqHandlerIMPORT ISR_IrqHandlerSTMFD sp!,r0-r12,lrBL ISR_IrqHandler ;跳转到C代码中异常中断处理程序ISR_IrqHandlerLDMFD sp!,r0

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

最新文档


当前位置:首页 > 高等教育 > 习题/试题

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