⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 startup.s

📁 一个基于lpc2220的uCosII操作系统的移植
💻 S
字号:
;define the stack size
;定义堆栈的大小
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

NoInt       EQU 0x80			;Bit7,I位
NoFIQ       EQU 0x40			;Bit6,F位

USR32Mode   EQU 0x10			;M[4:0]=10000,用户模式
SVC32Mode   EQU 0x13			;M[4:0]=10011,管理模式
SYS32Mode   EQU 0x1f			;M[4:0]=11111,系统模式
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
;引入的外部标号在这声明
    IMPORT  FIQ_Exception                   ;Fast interrupt exceptions handler 快速中断异常处理程序
    IMPORT  __main                          ;The entry point to the main function C语言主程序入口 
    IMPORT  TargetResetInit                 ;initialize the target board 目标板基本初始化
    IMPORT  SoftwareInterrupt

;The emported labels
;给外部使用的标号在这声明
    EXPORT  bottom_of_heap
    EXPORT  bottom_of_Stacks
    EXPORT  top_of_heap
    EXPORT  StackUsr
    
    EXPORT  Reset
    EXPORT __user_initial_stackheap

    CODE32

    AREA    vectors,CODE,READONLY
        ENTRY						;程序入口

;interrupt vectors
;中断向量表
Reset
        LDR     PC, ResetAddr			;0x00,复位
        LDR     PC, UndefinedAddr		;0x04,未定义指令异常
        LDR     PC, SWI_Addr			;0x08,软中断
        LDR     PC, PrefetchAddr		;0x0C,预取中止
        LDR     PC, DataAbortAddr		;0x10,预取数据中止
        DCD     0xb9205f80				;0x14,保留
        LDR     PC, [PC, #-0xff0]		;0x18,IRQ异常
        LDR     PC, FIQ_Addr			;0x1C,FIQ异常

ResetAddr           DCD     ResetInit			;复位初始化处理程序地址
UndefinedAddr       DCD     Undefined			;未定义指令处理程序地址
SWI_Addr            DCD     SoftwareInterrupt	;软件中断处理程序地址
PrefetchAddr        DCD     PrefetchAbort		;预取指中止处理程序地址
DataAbortAddr       DCD     DataAbort			;数据中止处理程序地址
Nouse               DCD     0					;未使用
IRQ_Addr            DCD     0					;IRQ中断,已在"LDR     PC, [PC, #-0xff0]"中处理
FIQ_Addr            DCD     FIQ_Handler			;快速中断处理程序地址


;未定义指令
Undefined
        B       Undefined		;死循环

;取指令中止							;LPC2100模板中的原文
PrefetchAbort
        B       PrefetchAbort		;死循环

;取数据中止
DataAbort
        B       DataAbort			;死循环

;快速中断
FIQ_Handler
        STMFD   SP!, {R0-R3, LR}	;寄存器R0~R3,LR入栈
        BL      FIQ_Exception		;调用FIQ处理程序(在target.c中)
        LDMFD   SP!, {R0-R3, LR}	;寄存器R0~R3,LR出栈
        SUBS    PC,  LR,  #4		;计算返回地址
        
;/*********************************************************************************************************
;** unction name 	函数名称: 	InitStack
;** Descriptions 	功能描述: 	Initialize the stacks  初始化堆栈
;** input parameters 	输 入:   	None 无
;** Returned value   	输 出 :  	None 无
;** Used global variables 全局变量: 	None 无
;** Calling modules 	调用模块: 	None 无
;** 
;** Created by 		作 者: 	Chenmingji 陈明计
;** Created Date 	日 期: 	2004/02/02 2004年2月2日
;**-------------------------------------------------------------------------------------------------------
;** Modified by 	修 改: 
;** Modified date 	日 期: 
;**-------------------------------------------------------------------------------------------------------
;********************************************************************************************************/
;初始化堆栈,此时禁止IRQ(I=1)、禁止FIQ(F=1)、ARM状态(T=0)
InitStack    
        MOV     R0, LR
;Build the SVC stack
;设置管理模式堆栈
        MSR     CPSR_c, #0xd3		
        LDR     SP, StackSvc	
;Build the IRQ stack	
;设置中断模式堆栈
        MSR     CPSR_c, #0xd2
        LDR     SP, StackIrq
;Build the FIQ stack
;设置快速中断模式堆栈
        MSR     CPSR_c, #0xd1
        LDR     SP, StackFiq
;Build the DATAABORT stack
;设置中止模式堆栈
        MSR     CPSR_c, #0xd7
        LDR     SP, StackAbt
;Build the UDF stack
;设置未定义模式堆栈
        MSR     CPSR_c, #0xdb
        LDR     SP, StackUnd
;Build the SYS stack
;设置系统模式堆栈
        MSR     CPSR_c, #0xdf		;切换到系统模式运行,之后将在系统模式下运行,除非进行模式切换
        LDR     SP, =StackUsr

        MOV     PC, R0				;返回

;/*********************************************************************************************************
;** unction name 	函数名称: 	ResetInit
;** Descriptions 	功能描述: 	RESET  复位入口
;** input parameters 	输 入:   	None 无
;** Returned value   	输 出 :  	None 无
;** Used global variables 全局变量: 	None 无
;** Calling modules 	调用模块: 	None 无
;** 
;** Created by 		作 者: 	Chenmingji 陈明计
;** Created Date 	日 期: 	2004/02/02 2004年2月2日
;**-------------------------------------------------------------------------------------------------------
;** Modified by 	修 改: Chenmingji 陈明计
;** Modified date 	日 期: 2004/02/02 2004年3月3日
;**-------------------------------------------------------------------------------------------------------
;********************************************************************************************************/
ResetInit
;Initial extenal bus controller.
;初始化外部总线控制器,根据目标板决定配置

        LDR     R0, =PINSEL2
    IF :DEF: EN_CRP
        LDR     R1, =0x0f814910
    ELSE
        LDR     R1, =0x0f814914
    ENDIF
        STR     R1, [R0]
        
; 定义总线速度控制字
BCFG_DEF	EQU		0x10000400

IDCY		EQU		(0x00<<0)
WST1		EQU		(0x01<<5)
WST2		EQU		(0x01<<11)
BCFG3_SET	EQU		(BCFG_DEF | IDCY | WST1 | WST2)


IDCYFS		EQU		(0x01<<0)
WST1FS		EQU		(0x03<<5)
WST2FS		EQU		(0x03<<11)
BCFG_FS     EQU		(BCFG_DEF | IDCYFS | WST1FS | WST2FS)
        

        LDR     R0, =BCFG0
        LDR     R1, =BCFG_FS
        STR     R1, [R0]

        LDR     R0, =BCFG1
        LDR     R1, =BCFG_FS
        STR     R1, [R0]

        LDR     R0, =BCFG2
        LDR     R1, =0x1000ffef
        STR     R1, [R0]

        LDR     R0, =BCFG3
        LDR     R1, =BCFG3_SET
        STR     R1, [R0]
        
        BL      InitStack               ;初始化堆栈 Initialize the stack
        BL      TargetResetInit         ;目标板基本初始化 Initialize the target board
        B       __main					;跳转到c语言入口 Jump to the entry point of C program

;/*********************************************************************************************************
;** unction name 	函数名称: 	__user_initial_stackheap
;** Descriptions 	功能描述: 	Initial the function library stacks and heaps, can not deleted!   库函数初始化堆和栈,不能删除
;** input parameters 	输 入:   	reference by function library 参考库函数手册
;** Returned value   	输 出 :  	reference by function library 参考库函数手册
;** Used global variables 全局变量: 	None 无
;** Calling modules 	调用模块: 	None 无
;** 
;** Created by 		作 者: 	Chenmingji 陈明计
;** Created Date 	日 期: 	2004/02/02 2004年2月2日
;**-------------------------------------------------------------------------------------------------------
;** Modified by 	
;** Modified date 	
;**-------------------------------------------------------------------------------------------------------
;********************************************************************************************************/
;库函数初始化堆和栈,不能删除
__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		;IRQ模式堆栈
StackFiq           DCD     FiqStackSpace + (FIQ_STACK_LEGTH - 1)* 4		;FIQ模式堆栈
StackAbt           DCD     AbtStackSpace + (ABT_STACK_LEGTH - 1)* 4		;中止模式堆栈
StackUnd           DCD     UndtStackSpace + (UND_STACK_LEGTH - 1)* 4	;未定义模式堆栈

;/*********************************************************************************************************
;** unction name 	函数名称: 	CrpData
;** Descriptions 	功能描述: 	encrypt the chip
;** input parameters 	输 入:   	None 无
;** Returned value   	输 出 :  	None 无
;** Used global variables 全局变量: 	None 无
;** Calling modules 	调用模块: 	None 无
;** 
;** Created by 		作 者: 	Chenmingji 陈明计
;** Created Date 	日 期: 	2004/03/27 2004年3月27日
;**-------------------------------------------------------------------------------------------------------
;** Modified by 	修 改: 
;** Modified date 	日 期: 
;**-------------------------------------------------------------------------------------------------------
;********************************************************************************************************/
;芯片加密
    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
    WEND
CrpData1
    DCD     0x87654321          ;/*When the Data is 为0x87654321,user code be protected. 当此数为0x87654321时,用户程序被保护 */
    ENDIF
    
;/* 分配堆栈空间 */
        AREA    MyStacks, DATA, NOINIT, ALIGN=2	;MyStacks通过分散加载文件定位
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通过分散加载文件定位
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通过分散加载文件定位
StackUsr

    END
;/*********************************************************************************************************
;**                            End Of File
;********************************************************************************************************/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -