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

📄 startup.s

📁 周立功PXA270教学实验箱的ARM汇编指令实验2
💻 S
字号:
;/****************************************Copyright (c)**************************************************
;**                               Guangzhou ZHIYUAN electronics Co.,LTD.
;**                                     
;**                                 http://www.zyinside.com
;**
;**--------------File Info-------------------------------------------------------------------------------
;** File Name: startup.s
;** Last modified Date: 2006-8-10
;** Last Version: v1.0
;** Description: PXA27x异常向量表与c语言代码的接口,包括初始化堆栈、堆空间分配、打开/禁止中断的代码
;**
;**------------------------------------------------------------------------------------------------------
;** Created By: 黄绍斌
;** Created date: 2006-8-10
;** Version: v1.0
;** Descriptions:
;**
;**------------------------------------------------------------------------------------------------------
;** Modified by:
;** Modified date:
;** Version:
;** Description:
;**
;********************************************************************************************************/

;define the stack size
;定义堆栈的大小
SVC_STACK_LEGTH         EQU         32
FIQ_STACK_LEGTH         EQU         32
IRQ_STACK_LEGTH         EQU         128
ABT_STACK_LEGTH         EQU         0
UND_STACK_LEGTH         EQU         0


USR32Mode   EQU 0x10
SVC32Mode   EQU 0x13
SYS32Mode   EQU 0x1f
IRQ32Mode   EQU 0x12
FIQ32Mode   EQU 0x11

I_BIT       EQU 0x80 	; when I bit is set (1), IRQ is disabled
F_BIT       EQU 0x40 	; when F bit is set (1), FIQ is disabled


   
;The imported labels
;引入的外部标号在这声明
    IMPORT  FIQ_Exception                   ;Fast interrupt exceptions handler 快速中断异常处理程序
    IMPORT  IRQ_Exception                   ;interrupt exceptions handler IRQ中断异常处理程序    
    IMPORT  TargetResetInit                 ;initialize the target board 目标板基本初始化
    IMPORT  __main                          ;The entry point to the main function C语言主程序入口 


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

    CODE32

    AREA    vectors,CODE,READONLY
   	ENTRY

;interrupt vectors
;中断向量表
Reset
        LDR     PC, ResetAddr
        LDR     PC, UndefinedAddr
        LDR     PC, SWI_Addr
        LDR     PC, PrefetchAddr
        LDR     PC, DataAbortAddr
        DCD     0
        LDR     PC, IRQ_Addr
        LDR     PC, FIQ_Addr

ResetAddr           DCD     ResetInit
UndefinedAddr       DCD     Undefined
SWI_Addr            DCD     SoftwareInterrupt
PrefetchAddr        DCD     PrefetchAbort
DataAbortAddr       DCD     DataAbort
Nouse               DCD     0
IRQ_Addr            DCD     IRQ_Exception
FIQ_Addr            DCD     FIQ_Handler


;未定义指令
Undefined
        B       Undefined

;软中断
SoftwareInterrupt			                               
        CMP     R0, #4
        LDRLO   PC, [PC, R0, LSL #2]
        MOVS    PC, LR

SwiFunction
        DCD     IRQDisable       ;0
        DCD     IRQEnable        ;1
        DCD		FIQDisable		 ;2
        DCD		FIQEnable		 ;3

IRQDisable
        ; 关IRQ中断
        MRS     R0, SPSR
        ORR     R0, R0, #I_BIT
        MSR     SPSR_c, R0
        MOVS    PC, LR

IRQEnable
        ; 开IRQ中断
        MRS     R0, SPSR
        BIC     R0, R0, #I_BIT
        MSR     SPSR_c, R0
        MOVS    PC, LR
        
FIQDisable
        ; 关FIQ中断
        MRS     R0, SPSR
        ORR     R0, R0, #F_BIT
        MSR     SPSR_c, R0
        MOVS    PC, LR

FIQEnable
        ; 开FIQ中断
        MRS     R0, SPSR
        BIC     R0, R0, #F_BIT
        MSR     SPSR_c, R0
        MOVS    PC, LR

;取指令中止
PrefetchAbort
        B       PrefetchAbort

;取数据中止
DataAbort
        B       DataAbort

;快速中断
FIQ_Handler
        STMFD   SP!, {R0-R3, LR}
        BL      FIQ_Exception
        LDMFD   SP!, {R0-R3, LR}
        SUBS    PC,  LR,  #4
        


;/*********************************************************************************************************
;** Function name: InitStack
;** Descriptions: 初始化堆栈
;** Input: 无
;** Output: 无
;** Created by: 陈明计
;** Created Date: 2004-02-02
;**-------------------------------------------------------------------------------------------------------
;** Modified by: 黄绍斌
;** Modified Date: 2006-8-10 
;**------------------------------------------------------------------------------------------------------
;********************************************************************************************************/
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

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        
        

;/*********************************************************************************************************
;** Function name: ResetInit
;** Descriptions: 复位入口
;** Input: 无
;** Output: 无
;** Created by: 陈明计
;** Created Date: 2004-02-02
;**-------------------------------------------------------------------------------------------------------
;** Modified by: 黄绍斌
;** Modified Date: 2006-8-10 
;**------------------------------------------------------------------------------------------------------
;********************************************************************************************************/
ResetInit        
        BL      InitStack               ;初始化堆栈 Initialize the stack
        BL		DisableMMU				;关闭MMU功能 Disable MMU
        BL      TargetResetInit         ;目标板基本初始化 Initialize the target board
                                        
        B       __main					;跳转到c语言入口 Jump to the entry point of C program
        
        
         	
;/*********************************************************************************************************
;** Function name: Read_CLKCFG
;** Descriptions: 读取CLKCFG的值(p14)
;** Input: 无
;** Output: R0为读出的值
;** Created by: 黄绍斌
;** Created Date: 2006-8-10 
;**-------------------------------------------------------------------------------------------------------
;** Modified by: 
;** Modified Date: 
;**------------------------------------------------------------------------------------------------------
;********************************************************************************************************/ 	
Read_CLKCFG                        
        MRC     p14,0,R0,c6,c0,0        ; 读取CLKCFG寄存器           
        MOV     PC,LR  
        

;/*********************************************************************************************************
;** Function name: Write_CLKCFG
;** Descriptions: 写CLKCFG寄存器(p14)
;** Input: R0	即为设置值
;** Output: 无
;** Created by: 黄绍斌
;** Created Date: 2006-8-10 
;**-------------------------------------------------------------------------------------------------------
;** Modified by: 
;** Modified Date: 
;**------------------------------------------------------------------------------------------------------
;********************************************************************************************************/ 	
Write_CLKCFG
        MCR     p14,0,R0,c6,c0,0        ; 写CLKCFG寄存器        
        MOV     PC,LR   


;/*********************************************************************************************************
;** Function name: DisableMMU
;** Descriptions: 禁止MMU
;** Input: 无
;** Output: 无
;** Created by: 黄绍斌
;** Created Date: 2006-8-10 
;**-------------------------------------------------------------------------------------------------------
;** Modified by: 
;** Modified Date: 
;**------------------------------------------------------------------------------------------------------
;********************************************************************************************************/
DisableMMU        	    
	    STMFD	SP!,{R0-R7,LR}	    
	    MOV		r0, #0x78
	    MCR		p15, 0, R0, c1, c0, 0              	    	
	    LDMFD	SP!,{R0-R7,PC}		; 返回操作        
	    


;/*********************************************************************************************************
;** Function name: __user_initial_stackheap
;** Descriptions: 库函数初始化堆和栈,不能删除
;** Input: 参考库函数手册
;** Output: 参考库函数手册
;** Created by: 陈明计
;** Created Date: 2004-02-02
;**-------------------------------------------------------------------------------------------------------
;** Modified by: 黄绍斌
;** Modified Date: 2006-8-10 
;**------------------------------------------------------------------------------------------------------
;********************************************************************************************************/
__user_initial_stackheap    
  		LDR   r0,=bottom_of_heap
    	MOV   pc,lr
    	
    	
   
;/* 分配堆栈空间 */
        AREA    MyStacks, DATA, NOINIT, ALIGN=2
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
bottom_of_heap    SPACE   1

        AREA    Stacks, DATA, NOINIT
StackUsr

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

⌨️ 快捷键说明

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