ARM 启动代码详解.docx
《ARM 启动代码详解.docx》由会员分享,可在线阅读,更多相关《ARM 启动代码详解.docx(9页珍藏版)》请在课桌文档上搜索。
1、ARM启动代码详解(Vectors.Ini1.s.Target.cTarget.h)2010-05-1516:03启动代码是芯片豆位后进入C语言的mainO函数前执行的一段代码,主要是为运行C语言程序提供根本运行环境,如初始化存储潺系统等。八RM公司只设计内核,不自C1.生产芯片,只是把内核授权给其它J.商,其它厂商购置了授权I1.参加自己的外设后生产出各具特色的芯片。这样就促进了基TARM处理器核的芯片多元化,但也使得每一种芯片的后动代码差异很大,不易编写出统一的启动代码,ADS(针对ARM处理器核的C语言编译器的策略是不提供完整的启动代码,启动代码缺乏局部或者由厂商提供,或者自己编写。启动
2、代码划分为4个文件:Vectors.C.Init.s.Target,c.Target.hoVeCtors.c包含异常向室表、堆栈初始化及中断效劳程序与C程序的接口。Init.s包含统初始化代码,并跳转到ADS提供的初始化代码.Targe1.C和Target.h包含目标板特殊的代码,包括异常处理程序和目标板初始化程序。这样做的目的是为了尽量减少正编代码,同时把不需要修改的代码独立出来以减少错误。4.2.1VeC1.Ors.c文件的编写4.2.1.1中断向量表nouscVectors1.DRPC.ResetAddr1.DRPC,UndefinedAddr1.DRPC,SW1.Addr1.DRPC,
3、PrefetchAddr1.DRPC,DataAbortAddrDCD0xb9205f801.DRPC,PC,K-OxffO1.DRPC,FQAddrResetAddrDCDResetUndefinedAddrDCDUndefinedSW1.AddrDCDSoftwareInterruptPrefetchAddrDCDPrefetchAbortDataAbortAddrDCDDatabortDCD0IRQ.AddrDCDIRQJIand1.erFIQ_AddrDCDFIQJIand1.er异常是由内部或外部源产生的以引起处理器处理的一个事件。八RM处理器核支持1种类型的异常。异常出现后,CPU
4、强制从异常类型对应的固定存储地址开始执行程序。这个固定的地址就是异常向员。向量从上到下依次为夏位、未定义指令异常、软件中断、预取指令中止、预取数据中止、保存的异常、IRQ和FIQ.IRQ向:ft“1.DRPC,PC,AOxffO*使用的指令与其它向下不同。在正常情况下这条指令所在地址为OXooOooO18。当CPU执行这条指令但还没有跳转时,PC的值为0X00000020,OXOoOoO020减去OXoOOOoFFo为OXFFFFFO30,这是向量中断控制器(VIC)的特殊存放器VICveCtAddr。这个存放器保存当前将要效劳的IRQ的中断效劳程序的入口,用这条指令就可以直接跳转到需要的中断
5、效劳程序中.至丁在保存的异常向垃“MD0xb9205f80位置填数据0xb9205f8是为了使向量表中所有的数据32位累加和为0。4.2.1.2初始化C1.t堆枝InitStackMOVR0,1.RMSRCPSR_c,S0xd2;设置中断模式堆栈1.DRSP1StackIrqMSRCPSRC,MXd1;设置快速中断模式堆栈1.DRSP,StackFiqMSRCPSRC,#0xd7;设置中止模式堆栈1.DKSP,StackAbtMSRCPSRc1.SOxdb:设置未定义模式堆栈1.DRSP1StackUndMSRCPSRc,#Oxdf;设置系统模式堆栈1.DRSP,StackSysMOVPC,R
6、OStackIrqDCD(IrqStackSpace+IRQ_STACK.EGTH*4-4)StackFiqDCD(FiqStackSpace+FQSTACIC1.EGTH*4-4)StackAbtDCD(AbtStackSpace+ABT_STACK1.EGTH*4-4)StackUndDCD(1.ndtStackSpace+UND_STACKIEGTH*4-4)StackSysDCD(SysStackSpace+SYS_STACK_1.EGTH*4-4);/*分配堆栈空间*/AREAMyStacks,DT,NO1.NITIrqStackSpaceSPACEIRQSTACK1.EGTH*4;
7、中断模式堆栈FiqStackSpaceSPACEF1.QSTACKJEGTH*4:快速中断模式推栈AbtStackSpaceSPACEAB1.STACKJEGTH*4;中止义模式堆枝UndtStackSpaceSPACEUV)STACK_1.EGTH*4;未定义模式堆栈SySSIaCkSpaCeSPACESYSSTACK1.EGTH*4;系统模式堆栈因为程序需要切换模式,而且程序退出时CP1.J的模式已经不再是管理模式而是系统模式1.R已经不再保存返回程序地址,所以程序首先把返回地址保存到Ro中,同时使用Ro返回。然后程序把处理器模式转化为IRQ模式,并设置IRQ模式的堆栈指针。其中变员Sta
8、CkIrq保存着IRQ模式的堆栈指针的初始值,Irqstackspace是分配给IRQ模式的堆栈空间的开始地址JRQSTACK1.EGTH是用户定义的常量,用于设置IRQ模式的堆枝空间的大小。程序使用同样的方法设置F1.Q模式堆栈指针、中止模式堆栈指针、未定义堆栈指针和系统模式堆栈指针。程序使用编译器分配的空间作为堆栈,而不是按照通常的做法把堆栈分配到RAM的顶端,之所以这样是因为这样做不必知道RAM顶端位置,移植更加方便:编译器给出的占用RAM空间的大小就是实际占用的大小,便于控制RAM的分配。对于1.PC2106来说,中止模式是不需要分配堆栈空间的,这是因为1.PC2106没有外部总线,也
9、没有虚拟内存机制,如果出现取数据中止或取指令中止肯定是程序有问题,而一般情况下也不需要模拟协处理器指令或扩充指令,未定义中止也就意味若程序有错误,也不需要分配堆栈空间。4.2.1.3异常处理代码与C语言的接口程序C0511中断效劳子程序流程图如图4T所示:51kaifkacom执行中断返回指令I手、-C返回)图4-1中断效劳子程序流程图异常处理代码与C语言的接口程序如卜丁MACRO$1RQ1.abe1.HAND1.ER$IRQExceptionEXPORT$IRQJabe1.的标号IMPoRTS1.RQException部标号$IRQ1.abe1.SUB1.R,1.R,#4;计算返回地址STM
10、I-DSP!,(R0-R3,R12,1.R):输出;引用的外:保存任务环R3,MRSSTMFDSP!,(R3)OSIntNesting+1.DRR2,=OSIntNesting*,1.DRBR1.,R2ADDR1.,R1.1#1STRBR1.,R2理程序B1.$IRQException:调用C语言的中断处MSRCPS1.1.c,#0x92:关中断B1.OSIntExit1.DRRO1=OSTCBHighRdy1.DRRO,R01.DRR1.,=OSTCBCur1.DRR1.,RUCMPRO1RI1.DMFDSP!,(R3)MSRSPSRcxsf,R31.DMEQFDSP!,R0-R3,R12,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- ARM 启动代码详解 启动 代码 详解
链接地址:https://www.desk33.com/p-1677770.html