当前位置:首页 > 单片机 > 单片机
[导读]2440init.s是启动代码的主文件,包括3个头文件,option.inc,memcfg.inc,2440addr.inc。 option.inc定义了3个堆栈起始地址,总线宽度,时钟相关参数的定义等。其中这个总线宽度将作为一个IF判断量,决定了各Bank的位

2440init.s是启动代码的主文件,包括3个头文件,option.inc,memcfg.inc,2440addr.inc。

option.inc定义了3个堆栈起始地址,总线宽度,时钟相关参数的定义等。其中这个总线宽度将作为一个IF判断量,决定了各Bank的位宽设置,参见memcfg.inc文件及datasheet。

memcfg.inc是存储器Bank的配置文件,定义了存储器相关寄存器位的值。各bank的位宽的设置定义也是在这个文件中,注意bank0的位宽没有相关的定义,因为它的位宽取决于OM[1:0]引脚,即启动方式。

2440addr.inc定义了相关寄存器地址,包括存储器控制寄存器,时钟电源管理寄存器,中断,看门狗,IO,NAND,杂项等相关用到的寄存器。

2440init.s是主要的启动代码文件,它配置了存储器,中断服务程序,堆栈等重要内容,并且最后开始跳到C代码。

Init段是开始点,跳转到ResetHandler。然后执行以下步骤:


禁止看门狗,禁止中断,禁止子中断,然后调节锁定时间,接着设定FCLK与HCLK与PCLK的比例1:2:4,然后设置UPLL为48M,延时7个时钟周期后设置MPLL为400M。


这时通过读取复位状态寄存器判断此时的复位到底是上电复位,唤醒复位还是看门狗复位等,如果是唤醒复位则跳转到相应位置然后释放SCLK,设置SDRAM,返回等。


如果不是唤醒复位则继续向下配置SDRAM,它实际上是把一个名为SMRDATA的数据缓冲池一个一个的送入相关的控制寄存器,相关的初始化配置的定义在memcfg.inc文件中。


然后跳转到初始化堆栈,具体以后再看。


接着读取BWSCON寄存器的相关位判断是从NOR还是NAND引导的,如果是NOR引导,则跳转到copy_proc_beg。


这部分主要是把RW区在ROM中的地址开始处搬移到RAM区,然后接着在这后面ZI区清0。


如果是NAND引导,则跳转到nand_boot_beg。


先配置NAND的时序参数和相关控制功能,然后跳转到ReadNandID等等,最后还是类似上面的完成RAM的复制,相关内容以后再学。


接着将IsrIRQ的地址放到HandleIRQ地址中。这样当中断发生后便能找到中断服务程序。


最后跳转到MAIN函数中,汇编部分的启动代码结束。

中断的内容详细解说如下:


首先,定义了一个宏,宏名为“$HandlerLabel HANDLER $HandleLabel”,这个宏展开后是一个以$HandlerLabel为入口名的代码段,例如“比如“HandlerIRQ HANDLER HandleIRQ”,宏执行以后将执行$HandleLabel地址中的内容,例如上则执行HandleIRQ地址中的内容。

当中断发生以后,ARM将从地址0x18处执行指令,即是一条跳转指令“bHandlerIRQ”,然后即是执行上面的宏,宏执行完以后则执行 HandleIRQ地址中的内容,而这正是入口名为IsrIRQ的代码部分。而IsrIRQ代码段的执行作用是首先读取INTOFFSET寄存器判断中断 源是哪个,记录其中断服务子程序的地址偏移量,然后将这个偏移量加上基地址,即EINT0中断服务子程序的入口地址所在的地址,最后从这个地址开始执行。

而所有的各个中断源触发的中断的中断服务子程序的入口地址都是固定的,所以在启动代码的后面有一个以_ISR_STARTADDRESS为开始的数据段,所有的地址名都是以Handle为开头的定义,如HandleTIMER0等。

当IsrIRQ执行后即从固定的中断服务子程序地址所在的地址处找到真正的中断服务子程序的地址,并执行之。


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

在嵌入式裸机编程中,堆栈初始化是系统启动过程中最关键的环节之一。它直接决定了程序能否从异常向量表正确跳转到main()函数,并确保后续函数调用和中断处理的可靠性。本文以ARM Cortex-M系列处理器为例,详细解析堆栈...

关键字: 裸机编程 启动代码

在我们使用keic51创建一个51单片机项目时,会有如下图所示的提示:keil创建新项目时,提示是否添加启动文件一般情况下,需要选择“是”。当然,也可以选择不加。那么,这个启动文件的作用是什么?什么情况下需要加,什么情况...

关键字: 51单片机 启动代码

ASSERT :DEF:ENDIAN_CHANGEASSERT :DEF:ENDIAN_CHANGE[ ENDIAN_CHANGEASSERT :DEF:ENTRY_BUS_WIDTH[ ENTRY_BUS_WIDTH=...

关键字: ARM 伪指令 启动代码 assert

1.1 启动代码内容1) 硬件初始化:最起码的是要初始化堆栈指针。2) C语言环境 :在main函数调用之前要完成对一些变量的初始化。3) 应用初始化: 这主要取决于你的应用。比如设置系统的晶振、时钟。1.2 图解M3启...

关键字: cortex-m3 启动代码

;******************** (C) COPYRIGHT 2010 STMicroelectronics ********************;* File Name: startup_stm32f10...

关键字: stm32f10x 启动代码

对于keil的启动代码(针对STM32F042),添加 备注 和 自己的理解;******************** (C) COPYRIGHT 2014 STMicroelectronics ************...

关键字: STM32 启动代码

●小容量产品是指闪存存储器容量在16K 至32K 字节之间的STM32F101xx、STM32F102xx和STM32F103xx微控制器。 对应后缀ld● 中容量产品是指闪存存储器容量在64K 至128K字节之间的ST...

关键字: STM32 启动代码 字节数

由于CPU和程序启动代码文件STARTUP.a51的重要性,一些8051派生的CPU产品要求初始化CPU来满足设计中的相应的硬件,因此,有时候用户需要对STARTUP.a51进行修改,所以进行注释一下:;--------...

关键字: C51 keil 启动代码

笔者前面章节简单介绍了s3c2416启动代码的实现过程,启动代码就是用来处理cpu体系结构中一些底层内容,一个功能强大的启动代码是可以当作bootloader(如uboot)来用的。有了启动代码,用户就可以专注于用c来作...

关键字: mdk s3c2416 启动代码 裸机开发

启动代码是处理器上电复位后最先运行的一段代码。主要是用来把处理器初始化到一个确定的状态,为c运行环境作好准备。如设置异常向量表,初始化系统时钟,初始化外部内存,把用户代码拷贝到外部内存,初始化栈,清0全

关键字: s3c2416 启动代码 流水灯 裸机开发
关闭