?? startup.s
字號(hào):
;/******************************************************************************************************
;** File name: Startup.s
;** Descriptions: The start up codes for LPC2200, including the initializing codes for the entry
; point of exceptions and the stacks of user tasks.Every project should have a
; independent copy of this file for related modifications.
;********************************************************************************************************/
;define the stack size
;定義堆棧的大小,根據(jù)需要改變
SVC_STACK_LEGTH EQU 0
FIQ_STACK_LEGTH EQU 0
IRQ_STACK_LEGTH EQU 256
ABT_STACK_LEGTH EQU 0
UND_STACK_LEGTH EQU 0
;用于置位程序狀態(tài)寄存器的I位(IRQ中斷屏蔽位)
NoInt EQU 0x80 ;Bit7,I位
USR32Mode EQU 0x10 ;M[4:0]=10000,用戶(hù)模式
SVC32Mode EQU 0x13 ;M[4:0]=10011,管理模式
SYS32Mode EQU 0x1f ;M[4:0]=1ffff,系統(tǒng)模式
IRQ32Mode EQU 0x12 ;M[4:0]=10010,IRQ中斷模式
FIQ32Mode EQU 0x11 ;M[4:0]=10001,快速中斷模式
PINSEL2 EQU 0xE002C014
BCFG0 EQU 0xFFE00000
BCFG1 EQU 0xFFE00004
BCFG2 EQU 0xFFE00008
BCFG3 EQU 0xFFE0000C
IMPORT __use_no_semihosting_swi
IMPORT __use_two_region_memory
;The imported labels
;引入的外部標(biāo)號(hào)在這聲明
IMPORT FIQ_Exception ;Fast interrupt exceptions handler 快速中斷異常處理程序
IMPORT __main ;The entry point to the main function C語(yǔ)言主程序入口
IMPORT TargetResetInit ;initialize the target board 目標(biāo)板基本初始化,在Target.c中
;The exported labels
;給外部使用的標(biāo)號(hào)在這聲明
EXPORT bottom_of_heap
EXPORT bottom_of_Stacks
EXPORT top_of_heap
EXPORT StackUsr
EXPORT Reset
EXPORT __user_initial_stackheap
;以下為異常向量表,聲明代碼段vectors
CODE32
AREA vectors,CODE,READONLY
ENTRY
;interrupt vectors
;中斷向量表
Reset
LDR PC, ResetAddr ;0x00,復(fù)位
LDR PC, UndefinedAddr ;0x04,未定義地址
LDR PC, SWI_Addr ;0x08,軟件中斷
LDR PC, PrefetchAddr ;0x0C,預(yù)取指中止
LDR PC, DataAbortAddr ;0x10,數(shù)據(jù)中止
DCD 0xb9205f80 ;0x14,保留,
LDR PC, [PC, #-0xff0] ;0x18,IRQ中斷
LDR PC, FIQ_Addr ;0x1C,快速中斷
ResetAddr DCD ResetInit ;復(fù)位初始化處理程序地址
UndefinedAddr DCD Undefined ;未定義指令處理程序地址
SWI_Addr DCD SoftwareInterrupt ;軟件中斷處理程序地址
PrefetchAddr DCD PrefetchAbort ;預(yù)取指中止處理程序地址
DataAbortAddr DCD DataAbort ;數(shù)據(jù)中止處理程序地址
Nouse DCD 0 ;未使用
IRQ_Addr DCD 0 ;IRQ中斷,已在LDR PC, [PC, #-0xff0]中處理
FIQ_Addr DCD FIQ_Handler ;快速中斷處理程序地址
;異常向量表結(jié)束
;未定義指令
Undefined
B Undefined ;死循環(huán)
;軟中斷
SoftwareInterrupt
B SoftwareInterrupt ;死循環(huán)
;取指令中止
PrefetchAbort
B PrefetchAbort ;死循環(huán)
;取數(shù)據(jù)中止
DataAbort
B DataAbort ;死循環(huán)
;快速中斷
FIQ_Handler
STMFD SP!, {R0-R3, LR} ;寄存器R0~R3,LR入棧
BL FIQ_Exception ;調(diào)用FIQ處理程序(在Target.c中)
LDMFD SP!, {R0-R3, LR} ;寄存器R0~R3,LR出棧
SUBS PC, LR, #4 ;計(jì)算返回地址
;/*********************************************************************************************************
;** unction name 函數(shù)名稱(chēng): InitStack
;** Descriptions 功能描述: Initialize the stacks 初始化堆棧,此時(shí)禁止IRQ(I=1)、禁止FIQ(F=1)、ARM狀態(tài)(T=0)
;** input parameters 輸 入: None 無(wú)
;** Returned value 輸 出 : None 無(wú)
;** Used global variables 全局變量: None 無(wú)
;** Calling modules 調(diào)用模塊: None 無(wú)
;********************************************************************************************************/
InitStack
MOV R0, LR
;Build the SVC stack
;設(shè)置管理模式堆棧
MSR CPSR_c, #0xd3
LDR SP, StackSvc
;Build the IRQ stack
;設(shè)置中斷模式堆棧
MSR CPSR_c, #0xd2
LDR SP, StackIrq
;Build the FIQ stack
;設(shè)置快速中斷模式堆棧
MSR CPSR_c, #0xd1
LDR SP, StackFiq
;Build the DATAABORT stack
;設(shè)置中止模式堆棧
MSR CPSR_c, #0xd7
LDR SP, StackAbt
;Build the UDF stack
;設(shè)置未定義模式堆棧
MSR CPSR_c, #0xdb
LDR SP, StackUnd
;Build the SYS stack
;設(shè)置系統(tǒng)模式堆棧
MSR CPSR_c, #0xdf ;切換到系統(tǒng)模式,之后將在系統(tǒng)模式下運(yùn)行
LDR SP, =StackUsr ;除非進(jìn)行模式切換
MOV PC, R0
;/*********************************************************************************************************
;** unction name 函數(shù)名稱(chēng): ResetInit
;** Descriptions 功能描述: RESET 復(fù)位入口
;** input parameters 輸 入: None 無(wú)
;** Returned value 輸 出 : None 無(wú)
;** Used global variables 全局變量: None 無(wú)
;** Calling modules 調(diào)用模塊: None 無(wú)
;********************************************************************************************************/
ResetInit
;Initial extenal bus controller.
;初始化外部總線(xiàn)控制器,根據(jù)目標(biāo)板決定配置
LDR R0, =PINSEL2
IF :DEF: EN_CRP
LDR R1, =0x0f814910
ELSE
LDR R1, =0x0f814914
ENDIF
STR R1, [R0]
LDR R0, =BCFG0
LDR R1, =0x1000ffef
STR R1, [R0]
LDR R0, =BCFG1
LDR R1, =0x1000ffef
STR R1, [R0]
; LDR R0, =BCFG2
; LDR R1, =0x2000ffef
; STR R1, [R0]
; LDR R0, =BCFG3
; LDR R1, =0x2000ffef
; STR R1, [R0]
BL InitStack ;初始化堆棧 Initialize the stack
BL TargetResetInit ;目標(biāo)板基本初始化 Initialize the target board
;跳轉(zhuǎn)到c語(yǔ)言入口 Jump to the entry point of C program
B __main
;/*********************************************************************************************************
;** unction name 函數(shù)名稱(chēng): __user_initial_stackheap
;** Descriptions 功能描述: Initial the function library stacks and heaps, can not deleted! 庫(kù)函數(shù)初始化堆和棧,不能刪除
;** input parameters 輸 入: reference by function library 參考庫(kù)函數(shù)手冊(cè)
;** Returned value 輸 出 : reference by function library 參考庫(kù)函數(shù)手冊(cè)
;** Used global variables 全局變量: None 無(wú)
;** Calling modules 調(diào)用模塊: None 無(wú)
;********************************************************************************************************/
__user_initial_stackheap
LDR r0,=bottom_of_heap
; LDR r1,=StackUsr
LDR r2,=top_of_heap
LDR r3,=bottom_of_Stacks
MOV pc,lr
StackSvc DCD SvcStackSpace + (SVC_STACK_LEGTH - 1)* 4
StackIrq DCD IrqStackSpace + (IRQ_STACK_LEGTH - 1)* 4
StackFiq DCD FiqStackSpace + (FIQ_STACK_LEGTH - 1)* 4
StackAbt DCD AbtStackSpace + (ABT_STACK_LEGTH - 1)* 4
StackUnd DCD UndtStackSpace + (UND_STACK_LEGTH - 1)* 4
;/*********************************************************************************************************
;** unction name 函數(shù)名稱(chēng): CrpData
;** Descriptions 功能描述: encrypt the chip
;** input parameters 輸 入: None 無(wú)
;** Returned value 輸 出 : None 無(wú)
;** Used global variables 全局變量: None 無(wú)
;** Calling modules 調(diào)用模塊: None 無(wú)
;********************************************************************************************************/
;芯片加密
IF :DEF: EN_CRP
IF . >= 0x1fc
INFO 1,"\nThe data at 0x000001fc must be 0x87654321.\nPlease delete some source before this line."
ENDIF
CrpData
WHILE . < 0x1fc
NOP ;/*循環(huán)用NOP填充,直到0x1FC*/
WEND
CrpData1
DCD 0x87654321 ;/*When the Data is 為0x87654321,user code be protected. 當(dāng)此數(shù)為0x87654321時(shí),用戶(hù)程序被保護(hù) */
ENDIF
;/* 分配堆棧空間 */
AREA MyStacks, DATA, NOINIT, ALIGN=2 ;MyStacks通過(guò)分散加載文件定位
SvcStackSpace SPACE SVC_STACK_LEGTH * 4 ;Stack spaces for Administration Mode 管理模式堆棧空間
IrqStackSpace SPACE IRQ_STACK_LEGTH * 4 ;Stack spaces for Interrupt ReQuest Mode 中斷模式堆棧空間
FiqStackSpace SPACE FIQ_STACK_LEGTH * 4 ;Stack spaces for Fast Interrupt reQuest Mode 快速中斷模式堆棧空間
AbtStackSpace SPACE ABT_STACK_LEGTH * 4 ;Stack spaces for Suspend Mode 中止義模式堆棧空間
UndtStackSpace SPACE UND_STACK_LEGTH * 4 ;Stack spaces for Undefined Mode 未定義模式堆棧
AREA Heap, DATA, NOINIT ;Heap通過(guò)分散加載文件定位
bottom_of_heap SPACE 1
AREA StackBottom, DATA, NOINIT
bottom_of_Stacks SPACE 1
AREA HeapTop, DATA, NOINIT
top_of_heap
AREA Stacks, DATA, NOINIT ;Stacks通過(guò)分散加載文件定位
StackUsr
END
;/*********************************************************************************************************
;** End Of File
;********************************************************************************************************/
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -