你现在位置:首页>技术论文>电气常识>嵌入式系统>正文
S3C2410快速启动的实现
日期:2008-6-25 0:12:22 来源:本站整理  
点击: 作者:
点击【】放大字体.
摘 要:介绍 S3C2410 处理器的快速启动技术,重点对系统硬件的初始化,二级中断向量表的复制,代码段的复制以及 MMU 管理进行了探讨,并且对具体的实现代码进行了分析,实现了系统从 RAM 中的高速启动运行。 
——可——编——程——控-制-器-技——术——门——户

关键词: S3C2410 ;快速启动; MMU 
P_L_C_技_术_网——可——编——程——控-制-器-技——术——门——户

嵌入式系统对功能、可靠性、成本、体积、功耗等均有严格要求,以 ARM 体系结构为基础的各种 RISC 微处理器具有灵活的特性和强大的性能,在嵌入式系统中得到了广泛的应用。 
WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

S3C2410 是三星公司基于 ARM920T 设计的一款处理器,在开发基于S3C2410的系统的过程中,如何让系统快速稳定地启动是一个重要问题。嵌入式系统的资源有限,程序通常都是固化在 ROM 中运行。但在实际应用中,为提高系统的实时性,加快代码的执行速度,系统启动后程序往往要被搬移到 RAM 中,因为 RAM 的存取速度要比 ROM 快得多,这样大大提升系统的性能。启动程序要完成的任务包括:硬件初始化,系统存储系统的配置,复制二级中断向量表。 
WW.W_PLCJS_COM-PLC-技.术_网

启动程序过程 
P_L_C_技_术_网——可——编——程——控-制-器-技——术——门——户

系统硬件初始化 
WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

系统上电或复位后,程序从位于地址 0x0 的 Reset Exception Vector 处开始执行,因此需要在这里放置 Bootloader 的第一条指令: b ResetHandler ,跳转到标号为 ResetHandler 处进行第一阶段的硬件初始化,主要内容为:关看门狗定时器,关中断,初始化 PLL 和时钟,初始化存储器系统。执行完以上程序后,系统进行堆栈和存储器的初始化。系统堆栈初始化取决于用户使用了哪些中断,以及系统需要处理哪些错误类型。一般情况下,管理者堆栈必须设置,如果使用了 IRQ 中断,则 IRQ 堆栈也必须设置。如果系统使用了外设,则需要设置相关的寄存器,以确定其刷新频率、总线宽度等信息。 
——可——编——程——控-制-器-技——术——门——户

代码段复制到 RAM 中运行 
WWW_PLC※JS_COM-PmLC-技.术_网

因为嵌入式系统的代码通常都是固化在 ROM 或者 Flash 中,上电后开始运行。由于 ROM 和 Flash 的读取速度相对较慢,这样无疑会降低代码的执行速度和系统的运行效率。为此,需要把系统的代码复制到 RAM 中运行。使用 SDT 链接器 ARMLink 产生的定位信息,把 RO 的有效代码和数据段到 RAM 中。 ARMLink 将编译后的程序链接成 ELF 文件。映像文件内部共有三种输出段: RO 段、 RW 段和 ZI 段。这三种输出段分别包含了只读代码及包含在代码段中的少量数据、可读写的数据、初始化为 0 的数据, ARMLink 同时还产生了这三种输出段的起始和终止定位信息: Image$$RO$$Base 、 Image$$RO$$Limit 、 Image$$RW$$Base 、 Image$$Limit 、 Image$$Linit 和 Image$$ZI$$Limit 。可以在程序中使用这些定位信息。将 ROM 中的代码和数据搬移到 RAM 中,具体程序如下。 
P.L.C.技.术.网——可编程控制器技术门户

LDR r0, =|Image$$RO$$Base| /*RO 段起始地址 */ 
P.L.C.技.术.网——可编程控制器技术门户

LDR r1, =|Image$$RO$$Limit| /*RO 段结束地址 */ 
WWW_PLCJS_COM-PLC-技.术_网

LDR r2, =|Image$$RW$$Base| 
W1WW_P4LCJS_COM-PLC-技.术_网

LDR r3, =|Image$$RW$$Limit| 
P.L.C.技.术.网——可编程控制器技术门户

/* 分别求出需要映像的代码和数据的长度并累加,放到寄存器 R1 中 */ 
WWcW_PLCJS_COM-PLC-技.术_网

SUB r1, r1, r0 
WWW_PLCJ-S_COM-PLC-技.术_网(可-编程控-制器技术-门户)

SUB r3, r3, r2 
WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

ADD r1, r1, r3 
WWW_P※LCJS_COM-PLC-)技.术_网

/* 将需要映象的代码和数据复制到 RAM 中去 */ 
WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

0 /* 标示符 */ 
WWW_PLC※JS_COM-PLC-技.术_网(可编程控※制器技术门户)

LDR r3, [r0], #4 
WWW_PLCJS_COM-PLC-技.术_网

STR r3, [r2], #4 
WW.W_PLCJS_COM-PLC-技.术_网

SUBS r1, r1, #4 
P.L.C.技.术.网——可编程控制器技术门户

BNE %B0 /* 如果没有复制完,跳转到 0 标示符处的汇编语句,继续复制,参见 ARM 指令帮助手册 */ 
WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

建立二级中断向量表 
WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

在 ARM 系统中,中断向量表位于 0X0 开始的地址处,意味着无论运行什么样的上层软件,一旦发生中断,程序就得到 Flash 存储器中的中断向量表里去,降低系统的运行效率。因此在 RAM 中建立自己的二级中断向量表,当中断发生后,程序直接从 RAM 中取中断向量进入中断子程序。尤其是在中断频繁发生的系统里,这种方法可以大大提高系统的运行效率,具体的实现代码如下。 
WWW.PLCJS.COM——可编程控制器技术门户

b ResetHandler 
——可——编——程——控-制-器-技——术——门——户

b HandlerUndef /* 未定义模式句柄 */ 
WWW_P※LCJS_COM-PLC-)技.术_网

b HandlerSWI /*SWI 中断句柄 */ 
P.L.C.技.术.网——可编程控制器技术门户

b HandlerPabort /*PAbort 中断句柄 */ 
WWcW_PLCJS_COM-PLC-技.术_网

b HandlerDabort /*Dabort 中断句柄 */ 
WWW_P※LCJS_COM-PLC-)技.术_网

b. /* 保留 */ 
W1WW_P4LCJS_COM-PLC-技.术_网

b HandlerIRQ /*IRQ 中断句柄 */ 
WWW_PLCJS_COM-PLC-技.术_网

b HandlerFIQ /*FIQ 中断句柄 */ 
WWW_P※LCJS_CO※M-PLC-技-.术_网

HandlerFIQ HANDLER HandleFIQ 

本新闻共2页,当前在第11 2  
plcjs.技.术_网

评论内容
载入中...
载入中...
P
L
C



|










|


P
L
C









·最新招聘信息
·最新求职信息
·推荐产品
·推荐厂商
·栏目热门排行
·站内热门排行