當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]相對于ARM上一代的主流ARM7/ARM9內(nèi)核架構(gòu),新一代Cortex內(nèi)核架構(gòu)的啟動方式有了比較大的變化。ARM7/ARM9內(nèi)核的控制器在復(fù)位后,CPU會從存儲空間的絕對地址0x000000取出第一條指令執(zhí)行復(fù)位中斷服務(wù)程序的方式啟動,即

相對于ARM上一代的主流ARM7/ARM9內(nèi)核架構(gòu),新一代Cortex內(nèi)核架構(gòu)的啟動方式有了比較大的變化。ARM7/ARM9內(nèi)核的控制器在復(fù)位后,CPU會從存儲空間的絕對地址0x000000取出第一條指令執(zhí)行復(fù)位中斷服務(wù)程序的方式啟動,即固定了復(fù)位后的起始地址為0x000000(PC = 0x000000)同時(shí)中斷向量表的位置并不是固定的。而Cortex-M3內(nèi)核則正好相反,有3種情況:
1、 通過boot引腳設(shè)置可以將中斷向量表定位于SRAM區(qū),即起始地址為0x2000000,同時(shí)復(fù)位后PC指針位于0x2000000處;
2、 通過boot引腳設(shè)置可以將中斷向量表定位于FLASH區(qū),即起始地址為0x8000000,同時(shí)復(fù)位后PC指針位于0x8000000處;
3、 通過boot引腳設(shè)置可以將中斷向量表定位于內(nèi)置Bootloader區(qū),本文不對這種情況做論述;
而Cortex-M3內(nèi)核規(guī)定,起始地址必須存放堆頂指針,而第二個(gè)地址則必須存放復(fù)位中斷入口向量地址,這樣在Cortex-M3內(nèi)核復(fù)位后,會自動從起始地址的下一個(gè)32位空間取出復(fù)位中斷入口向量,跳轉(zhuǎn)執(zhí)行復(fù)位中斷服務(wù)程序。對比ARM7/ARM9內(nèi)核,Cortex-M3內(nèi)核則是固定了中斷向量表的位置而起始地址是可變化的。
有了上述準(zhǔn)備只是后,下面以STM32的2.02固件庫提供的啟動文件“stm32f10x_vector.s”為模板,對STM32的啟動過程做一個(gè)簡要而全面的解析。

程序清單一:
文件“stm32f10x_vector.s”,其中注釋為行號

DATA_IN_ExtSRAMEQU0;1Stack_SizeEQU0x00000400;2AREASTACK,NOINIT,READWRITE,ALIGN=3;3Stack_MemSPACEStack_Size;4__initial_sp;5Heap_SizeEQU0x00000400;6AREAHEAP,NOINIT,READWRITE,ALIGN=3;7__heap_base;8Heap_MemSPACEHeap_Size;9__heap_limit;10THUMB;11PRESERVE8;12IMPORTNMIException;13IMPORTHardFaultException;14IMPORTMemManageException;15IMPORTBusFaultException;16IMPORTUsageFaultException;17IMPORTSVCHandler;18IMPORTDebugMonitor;19IMPORTPendSVC;20IMPORTSysTickHandler;21IMPORTWWDG_IRQHandler;22IMPORTPVD_IRQHandler;23IMPORTTAMPER_IRQHandler;24IMPORTRTC_IRQHandler;25IMPORTFLASH_IRQHandler;26IMPORTRCC_IRQHandler;27IMPORTEXTI0_IRQHandler;28IMPORTEXTI1_IRQHandler;29IMPORTEXTI2_IRQHandler;30IMPORTEXTI3_IRQHandler;31IMPORTEXTI4_IRQHandler;32IMPORTDMA1_Channel1_IRQHandler;33IMPORTDMA1_Channel2_IRQHandler;34IMPORTDMA1_Channel3_IRQHandler;35IMPORTDMA1_Channel4_IRQHandler;36IMPORTDMA1_Channel5_IRQHandler;37IMPORTDMA1_Channel6_IRQHandler;38IMPORTDMA1_Channel7_IRQHandler;39IMPORTADC1_2_IRQHandler;40IMPORTUSB_HP_CAN_TX_IRQHandler;41IMPORTUSB_LP_CAN_RX0_IRQHandler;42IMPORTCAN_RX1_IRQHandler;43IMPORTCAN_SCE_IRQHandler;44IMPORTEXTI9_5_IRQHandler;45IMPORTTIM1_BRK_IRQHandler;46IMPORTTIM1_UP_IRQHandler;47IMPORTTIM1_TRG_COM_IRQHandler;48IMPORTTIM1_CC_IRQHandler;49IMPORTTIM2_IRQHandler;50IMPORTTIM3_IRQHandler;51IMPORTTIM4_IRQHandler;52IMPORTI2C1_EV_IRQHandler;53IMPORTI2C1_ER_IRQHandler;54IMPORTI2C2_EV_IRQHandler;55IMPORTI2C2_ER_IRQHandler;56IMPORTSPI1_IRQHandler;57IMPORTSPI2_IRQHandler;58IMPORTUSART1_IRQHandler;59IMPORTUSART2_IRQHandler;60IMPORTUSART3_IRQHandler;61IMPORTEXTI15_10_IRQHandler;62IMPORTRTCAlarm_IRQHandler;63IMPORTUSBWakeUp_IRQHandler;64IMPORTTIM8_BRK_IRQHandler;65IMPORTTIM8_UP_IRQHandler;66IMPORTTIM8_TRG_COM_IRQHandler;67IMPORTTIM8_CC_IRQHandler;68IMPORTADC3_IRQHandler;69IMPORTFSMC_IRQHandler;70IMPORTSDIO_IRQHandler;71IMPORTTIM5_IRQHandler;72IMPORTSPI3_IRQHandler;73IMPORTUART4_IRQHandler;74IMPORTUART5_IRQHandler;75IMPORTTIM6_IRQHandler;76IMPORTTIM7_IRQHandler;77IMPORTDMA2_Channel1_IRQHandler;78IMPORTDMA2_Channel2_IRQHandler;79IMPORTDMA2_Channel3_IRQHandler;80IMPORTDMA2_Channel4_5_IRQHandler;81AREARESET,DATA,READONLY;82EXPORT__Vectors;83__Vectors;84DCD__initial_sp;85DCDReset_Handler;86DCDNMIException;87DCDHardFaultException;88DCDMemManageException;89DCDBusFaultException;90DCDUsageFaultException;91DCD0;92DCD0;93DCD0;94DCD0;95DCDSVCHandler;96DCDDebugMonitor;97DCD0;98DCDPendSVC;99DCDSysTickHandler;100DCDWWDG_IRQHandler;101DCDPVD_IRQHandler;102DCDTAMPER_IRQHandler;103DCDRTC_IRQHandler;104DCDFLASH_IRQHandler;105DCDRCC_IRQHandler;106DCDEXTI0_IRQHandler;107DCDEXTI1_IRQHandler;108DCDEXTI2_IRQHandler;109DCDEXTI3_IRQHandler;110DCDEXTI4_IRQHandler;111DCDDMA1_Channel1_IRQHandler;112DCDDMA1_Channel2_IRQHandler;113DCDDMA1_Channel3_IRQHandler;114DCDDMA1_Channel4_IRQHandler;115DCDDMA1_Channel5_IRQHandler;116DCDDMA1_Channel6_IRQHandler;117DCDDMA1_Channel7_IRQHandler;118DCDADC1_2_IRQHandler;119DCDUSB_HP_CAN_TX_IRQHandler;120DCDUSB_LP_CAN_RX0_IRQHandler;121DCDCAN_RX1_IRQHandler;122DCDCAN_SCE_IRQHandler;123DCDEXTI9_5_IRQHandler;124DCDTIM1_BRK_IRQHandler;125DCDTIM1_UP_IRQHandler;126DCDTIM1_TRG_COM_IRQHandler;127DCDTIM1_CC_IRQHandler;128DCDTIM2_IRQHandler;129DCDTIM3_IRQHandler;130DCDTIM4_IRQHandler;131DCDI2C1_EV_IRQHandler;132DCDI2C1_ER_IRQHandler;133DCDI2C2_EV_IRQHandler;134DCDI2C2_ER_IRQHandler;135DCDSPI1_IRQHandler;136DCDSPI2_IRQHandler;137DCDUSART1_IRQHandler;138DCDUSART2_IRQHandler;139DCDUSART3_IRQHandler;140DCDEXTI15_10_IRQHandler;141DCDRTCAlarm_IRQHandler;142DCDUSBWakeUp_IRQHandler;143DCDTIM8_BRK_IRQHandler;144DCDTIM8_UP_IRQHandler;145DCDTIM8_TRG_COM_IRQHandler;146DCDTIM8_CC_IRQHandler;147DCDADC3_IRQHandler;148DCDFSMC_IRQHandler;149DCDSDIO_IRQHandler;150DCDTIM5_IRQHandler;151DCDSPI3_IRQHandler;152DCDUART4_IRQHandler;153DCDUART5_IRQHandler;154DCDTIM6_IRQHandler;155DCDTIM7_IRQHandler;156DCDDMA2_Channel1_IRQHandler;157DCDDMA2_Channel2_IRQHandler;158DCDDMA2_Channel3_IRQHandler;159DCDDMA2_Channel4_5_IRQHandler;160AREA|.text|,CODE,READONLY;161Reset_HandlerPROC;162EXPORTReset_Handler;163IFDATA_IN_ExtSRAM==1;164LDRR0,=0x00000114;165LDRR1,=0x40021014;166STRR0,[R1];167LDRR0,=0x000001E0;168LDRR1,=0x40021018;169STRR0,[R1];170LDRR0,=0x44BB44BB;171LDRR1,=0x40011400;172STRR0,[R1];173LDRR0,=0xBBBBBBBB;174LDRR1,=0x40011404;175STRR0,[R1];176LDRR0,=0xB44444BB;177LDRR1,=0x40011800;178STRR0,[R1];179LDRR0,=0xBBBBBBBB;180LDRR1,=0x40011804;181STRR0,[R1];182LDRR0,=0x44BBBBBB;183LDRR1,=0x40011C00;184STRR0,[R1];185LDRR0,=0xBBBB4444;186LDRR1,=0x40011C04;187STRR0,[R1];188LDRR0,=0x44BBBBBB;189LDRR1,=0x40012000;190STRR0,[R1];191LDRR0,=0x44444B44;192LDRR1,=0x40012004;193STRR0,[R1];194LDRR0,=0x00001011;195LDRR1,=0xA0000010;196STRR0,[R1];197LDRR0,=0x00000200;198LDRR1,=0xA0000014;199STRR0,[R1];200ENDIF;201IMPORT__main;202LDRR0,=__main;203BXR0;204ENDP;205ALIGN;206IF:DEF:__MICROLIB;207EXPORT__initial_sp;208EXPORT__heap_base;209EXPORT__heap_limit;210ELSE;211IMPORT__use_two_region_memory;212EXPORT__user_initial_stackheap;213__user_initial_stackheap;214LDRR0,=Heap_Mem;215LDRR1,=(Stack_Mem+Stack_Size);216LDRR2,=(Heap_Mem+Heap_Size);217LDRR3,=Stack_Mem;218BXLR;219ALIGN;220ENDIF;221END;222ENDIF;223END;224

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉