s3c2410启动代码分析

发布者:czl55555最新更新时间:2016-12-05 来源: eefocus关键字:S3C2410  启动代码 手机看文章 扫描二维码
随时随地手机看文章

嵌入式系统对功能、可靠性、成本、体积、功耗等均有严格要求,以ARM体系结构为基础的各种RISC微处理器具有灵活的特性和强大的性能,在嵌入式系统中得到了广泛的应用。
---S3C2410是三星公司基于ARM920T设计的一款处理器,在开发基于S3C2410的系统的过程中,如何让系统快速稳定地启动是一个重要问题。嵌入式系统的资源有限,程序通常都是固化在ROM中运行。但在实际应用中,为提高系统的实时性,加快代码的执行速度,系统启动后程序往往要被搬移到RAM中,因为RAM的存取速度要比ROM快得多,这样大大提升系统的性能。启动程序要完成的任务包括:硬件初始化,系统存储系统的配置,复制二级中断向量表。 
启动程序过程
● 系统硬件初始化
---系统上电或复位后,程序从位于地址0x0的Reset Exception Vector处开始执行,因此需要在这里放置Bootloader的第一条指令:b ResetHandler,跳转到标号为ResetHandler处进行第一阶段的硬件初始化,主要内容为:关看门狗定时器,关中断,初始化PLL和时钟,初始化存储器系统。执行完以上程序后,系统进行堆栈和存储器的初始化。系统堆栈初始化取决于用户使用了哪些中断,以及系统需要处理哪些错误类型。一般情况下,管理者堆栈必须设置,如果使用了IRQ中断,则IRQ堆栈也必须设置。如果系统使用了外设,则需要设置相关的寄存器,以确定其刷新频率、总线宽度等信息。
● 代码段复制到RAM中运行
---因为嵌入式系统的代码通常都是固化在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中,具体程序如下。
---LDR r0, =|Image$$RO$$Base| /*RO段起始地址*/
---LDR r1, =|Image$$RO$$Limit| /*RO段结束地址*/
---LDR r2, =|Image$$RW$$Base|
---LDR r3, =|Image$$RW$$Limit|
---/*分别求出需要映像的代码和数据的长度并累加,放到寄存器R1中*/
---SUB r1, r1, r0
---SUB r3, r3, r2
---ADD r1, r1, r3
---/*将需要映象的代码和数据复制到RAM中去*/
---0 /*标示符*/
---LDR r3, [r0], #4
---STR r3, [r2], #4
---SUBS r1, r1, #4
---BNE %B0 /*如果没有复制完,跳转到0标示符处的汇编语句,继续复制,参见ARM指令帮助手册*/
● 建立二级中断向量表
---在ARM系统中,中断向量表位于0X0开始的地址处,意味着无论运行什么样的上层软件,一旦发生中断,程序就得到Flash存储器中的中断向量表里去,降低系统的运行效率。因此在RAM中建立自己的二级中断向量表,当中断发生后,程序直接从RAM中取中断向量进入中断子程序。尤其是在中断频繁发生的系统里,这种方法可以大大提高系统的运行效率,具体的实现代码如下。
---b ResetHandler
---b HandlerUndef /*未定义模式句柄*/
---b HandlerSWI /*SWI中断句柄*/
---b HandlerPabort /*PAbort中断句柄*/
---b HandlerDabort /*Dabort中断句柄*/
---b. /*保留*/
---b HandlerIRQ /*IRQ 中断句柄*/
---b HandlerFIQ /*FIQ中断句柄*/
---HandlerFIQ HANDLER HandleFIQ
---HandlerIRQ HANDLER HandleIRQ
---HandlerUndef HANDLER HandleUndef
---HandlerSWI HANDLER HandleSWI
---HandlerDabort HANDLER HandleDabort
---HandlerPabort HANDLER HandlePabort
---其中HANDLER是一个宏,用于查找中断处理程序的入口地址。这些地址存放在由HandleXXX指向的表项中,该表定位在RAM高端,基地址为_ISR_STARTADDRESS。
---^ _ISR_STARTADDRESS
---HandleReset # 4
---HandleUndef # 4
---HandleSWI # 4
---HandlePabort # 4
---HandleDabort # 4
---HandleReserved # 4
---HandleIRQ # 4
---HandleFIQ # 4
● MMU的应用
---MMU是存储器管理单*的缩写,是用来管理虚拟内存系统的器件。MMU通常是CPU的一部分,本身有少量存储空间存放从虚拟地址到物理地址的匹配表,此表称作TLB(转换旁置缓冲区)。所有数据请求都送往MMU,由MMU决定数据是在RAM内还是在大容量外部存储器设备内。如果数据不在存储空间内,MMU将产生页面错误中断。MMU存储器系统的结构允许对存储器系统的精细控制,大部分的控制细节由存在存储器中的转换表提供。这些表的入口定义了从1KB~1MB的各种存储器区域的属性。MMU完成的两个主要功能是:将虚地址转换成物理地址,控制存储器存取允许。MMU关掉时,虚地址直接输出到物理地址总线。
---经过以上的分析可以发现,系统启动程序主要是完成了硬件的初始化,以及克服Flash或ROM读取速度慢的弱点,提高指令和数据的读取速度,实现系统的高速运行,并且通过MMU的应用,减少RAM的使用,降低系统成本。

关键字:S3C2410  启动代码 引用地址:s3c2410启动代码分析

上一篇:LCD驱动程序移植
下一篇:移植标准Linux到 S3C2410简介

推荐阅读最新更新时间:2024-03-16 15:23

WinCE-IIC调试助手(S3C2410)
这两天在调试一款新的硬件平台,它采用的MCU依然是S3C2410。该平台新增了一个RTC模块,采用的芯片是DS1337。这是一个IIC接口的时钟芯片。在开始调试时碰到了一些问题,MCU始终无法与DS1337通讯,走了些弯路,浪费了不少时间。后来发现是IIC的SDA和SCL接反了。为了以后能方便调试2410下的IIC设备,所以决定为2410的WinCE做一个IIC调试助手,以免下次再碰到类似的问题,而多花冤枉时间。 IIC调试助手的主要功能:检测S3C2410 IIC-Bus上的设备,并给出对应的Slave Address。这样,我们就可以快速判断硬件是否有问题。除了侦测设备,同时也要支持读和写的功能。通过选择,能方便控制IIC
[单片机]
WinCE-IIC调试助手(<font color='red'>S3C2410</font>)
基于GPRS 技术的电能质量在线监测系统
  0 引言   近年来,随着电力工业的飞速发展及电力系统容量不断扩大,各种分布式发电单元逐步接入电网,各种非线性负载使用也不断增加,造成公用电网电能质量日益恶化,而各种电子设备对电压扰动的敏感性有增无减。因此,电力运行对电力调度自动化水平的要求和安全性的要求越来越高。电力调度需要各种功能更为齐全、操作更为简便的各种电力检测仪器仪表,对电能质量扰动进行检测、定位和分类,以便及时治理。随着中国电力市场的逐步建立,电能逐步实现按质论价,电力用户也要求高质量的电能来保证其设备、仪器和系统的正常运行。   传统的电能质量监测仪表多采用RS - 485、光纤、Modem 拨号等有线传输方式,在偏远地区监测点分散,环境恶劣,涉及到布线施工
[单片机]
基于GPRS 技术的电能质量在线监测系统
ARM S3C2410硬件手册上的重要部分
a.Memory Controller b.Nand Flash c.UART d.Interrupt e.Timer Memory Controller SDRAM: S3C2410 提供了外接ROM、SRAM、SDRAM、NOR Flash、NAND Flash的接口。S3C2410外接存储器的空间被分为8 BANKS,每BANK容量为128M:当访问BANKx(x从0到7)所对应的地址范围x*128M到(x+1)*128M-1 SDRAM使用BANK6,它的物理起始地址为6*128M=0x30000000。 (注:bank就是片选,一个片选就是一个bank,在U-Boot中,配制的时候要配制SDRAM和FLAS
[单片机]
嵌入式ARM启动代码的工作
(1)定义代码的初始入口点:初始入口点是指代码运行时的起始点,它在每个映像文件中是唯一的,也是每个可执行的映像文件 所必须含有的,而且必须位于映像文件的可执行域内。 (2)设置中断向量表,链接到包括复位、未定义指令,软件中断、取指中断、取数中断、IRQ和FIQ等异常或中断的处理程序。 (3)初始化存储系统。 (4)初始化ARM各个模式下的堆栈:根据应用程序使用资源的情况,设置每种或者某些ARM处理器模式下的堆栈区域。 (5)始化关键的I/O设备:用于防止在使能中断时产生不必要的开销。 (6)初始化中断时需要使用的一些变量。 (7)中断使能。 (8)根据情况切换处理器的模式和状态:ARM在运行
[单片机]
嵌入式s3c2410A UART部分中文解释
异步串口通信 概述 S3C2410的UART提供3个独立的异步串行通信端口,每个端口可以基于中断或者DMA进行操作。换句话说,UART控制器可以在CPU和UART之间产生一个中断或者DMA请求来传输数据。UART在系统时钟下运行可支持高达230.4K的波特率,如果使用外部设备提供的UEXTCLK,UART的速度还可以更高。每个UART通道各含有两个16位的接收和发送FIFO。 S3C2410的UART包括可编程的波特率,红外 接收/发送,一个或两个停止位插入,5-8位数据宽度和奇偶校验。 每个UART包括一个波特率发生器、一个发送器、一个接收器和一个控制单元,如图11-1所示。波特率发生器的输入可以是PCLK或者UEX
[单片机]
嵌入式<font color='red'>s3c2410</font>A UART部分中文解释
基于嵌入式Linux图像采集恢复和应用
1.引言       随着后PC时代的到来和嵌入式的蓬勃发展,运用嵌入式系统实现远程数据采集已成为社会需求的趋势。本文采用嵌入式系统采集图像数据实现加工零件的远程测量,代替传统的人工检测。其特点有:网络化,准确性高,节约人力和物力。   2.系统软硬件平 台       由于嵌入式设备资源有限,所以在开发嵌入式系统的软件部分需要在宿主机平台上实现,运用宿主机的资源编译目标机平台上可运行的软件。本文系统的宿主机平台:Redhat 9.0,交叉编译环境:ARM-Linux-Gcc;目标机平台:UBOOT 1.1,Linux 2.4.18 和YAFFS 根文件系统。       系统硬件平台的处理器采用 Samsung 公司的集成
[嵌入式]
几乎是每个arm程序必备的启动代码
启动代码是几乎是每个arm程序程序必备的,刚开始看的时候看别人的启动代码时感觉云里雾里,所以懒惰的想法浮现脑中:别人都写好了我还写什么,直接拿来用不就行了,对在我懂得情况下,我一定会拿来就用,但是现在我还不懂,一切就要从头开始,经过几天的努力,现在的感觉是启动代码不过如此 :) ,呵呵。 ;--------------------------------------------------------------------- ;startup.s ;系统启动代码 ;起始时间 : 2009.5.7 ----- 2009.5.11 ;--------------------------------------------
[单片机]
几乎是每个arm程序必备的<font color='red'>启动</font><font color='red'>代码</font>
S3C2440 启动代码分析
启动代码是系统上电或复位以后运行的第一段代码,它的作用是在用户程序运行之前对系统硬件及软件运行环境进行必要的初始化并在最后使程序跳转到用户程序,它直接面对ARM 处理器内核及硬件控制器进行编程,所执行的操作与具体的目标系统紧密相关。 S3C2440 支持两种方式的启动:Nor Flash 启动和Nand Flash 启动。Nor Flash 和Nand Flash 都是非易失性存储器,Nor Flash 的特点是芯片内执行,程序可以直接在其中运行,而不必将程序读取到RAM 中运行。Nor Flash 虽然具有这个优点,但是它的性价比远低于Nand Flash,因而很多系统采用Nand Flash 启动。Nand Flash 的特
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved