亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cstartup.s79

?? s3c2410 example code , it s a simple code to use s3c2410.
?? S79
?? 第 1 頁 / 共 2 頁
字號:
;-----------------------------------------------------------------------------
; This file contains the startup code used by the ICCARM C compiler.
;
; The modules in this file are included in the libraries, and may be replaced
; by any user-defined modules that define the PUBLIC symbols ?cstartup etc.
; If this entire file is assembled and linked with the provided
; libraries, the XLINK option -C must be used to avoid a clash with 
; PROGRAM module ?RESET.
; EWARM also has a check box to "Ignore CSTARTUP in library", that has
; the same effect.
;
; All code in the modules (except ?RESET) will be placed in the ICODE segment,
; that must be reachable by a B instruction in ARM mode from segment INTVEC
; (within the first 32 Mbytes).
;
; Define preprocessor symbol __THUMB_LIBRARY__ for Thumb libraries
; or __ARM_LIBRARIES__ for ARM libraries.
;
; $Revision: 1.29 $
;
;-----------------------------------------------------------------------------

#include "compiler_option.h"
#include "4510addr.a"
#include "memcfg.a"

;  Make sure that __ARM_LIBRARY__ or __THUMB_LIBRARY__ is defined


#ifdef __ARM_LIBRARY__
#ifdef __THUMB_LIBRARY__
#error "Cannot have both __ARM_LIBRARY__ and __THUMB_LIBRARY__ set!"
#endif
#else
#ifndef __THUMB_LIBRARY__
#error "Must have one of  __ARM_LIBRARY__ or __THUMB_LIBRARY__ set!"
#endif
#endif

	
;
; Naming covention of labels in this file:
;
;  ?xxx	  - External labels only accessed from assembler.
;  __xxx  - External labels accessed from or defined in C.
;  xxx	  - Labels local to one module (note: this file contains
;	    several modules).
;  main	  - The starting point of the user program.
;

;---------------------------------------------------------------
; Macros and definitions for the whole file
;---------------------------------------------------------------

; Mode, correspords to bits 0-5 in CPSR
MODE_BITS	DEFINE	0x1F		; Bit mask for mode bits in CPSR
USER_MODE	DEFINE	0x10		; User mode
FIQ_MODE	DEFINE	0x11		; Fast Interrupt Request mode
IRQ_MODE	DEFINE	0x12		; Interrupt Request mode
SVC_MODE	DEFINE	0x13		; Supervisor mode
ABORT_MODE	DEFINE	0x17		; Abort mode
UNDEF_MODE	DEFINE	0x1B		; Undefined Instruction mode
SYS_MODE	DEFINE	0x1F		; System mode
MODE_MASK       DEFINE  0x1f
NOINT           DEFINE  0xc0

ROM0_SIZE				DEFINE		0x200000
SDRAM0_BASE_FOR_LOADER	DEFINE		0x1000000


#if __LITTLE_ENDIAN__==1
; RTMODEL attribute __endian

#define ENDIAN_MODE	"little"

#else
#define ENDIAN_MODE	"big"
#endif

	
#ifdef __THUMB_LIBRARY__

; RTMODEL attribute __cpu_mode
#define CPU_MODE_NAME	"thumb"
; Segment used for libraries
#define LIB_SEGMENT	NEARFUNC_T
SEGMENT_ALIGN	DEFINE	1		; Align Thumb segments to 2^1

CPU_MODE	MACRO
		CODE16
		ENDM

#else		/////// __ARM_LIBRARY__

; RTMODEL attribute __cpu_mode
#define CPU_MODE_NAME	"arm"
; Segment used for libraries
#define LIB_SEGMENT	NEARFUNC_A
SEGMENT_ALIGN	DEFINE	2		; Align ARM segments to 2^2

CPU_MODE	MACRO
		CODE32
		ENDM

#endif


;---------------------------------------------------------------
; ?RESET
; Reset Vector.
; Normally, segment INTVEC is linked at address 0.
; For debugging purposes, INTVEC may be placed at other
; addresses.
; A debugger that honors the entry point will start the
; program in a normal way even if INTVEC is not at address 0.
;---------------------------------------------------------------

        	PROGRAM	?RESET
		COMMON	INTVEC:CODE:ROOT(2)
		EXTERN	Addr_Reset,Addr_Undefined,Addr_Swi,Addr_Prefetch,Addr_Prefetch,Addr_Dabort,Addr_IRQ,Addr_FIQ
		CODE32	; Always ARM mode after reset	
		org	0	
reset		
                LDR     PC, Addr_Reset
                LDR     PC, Addr_Undefined
                LDR     PC, Addr_Swi
                LDR     PC, Addr_Prefetch
                LDR     PC, Addr_Dabort
                b	.                            ; Reserved
                LDR     PC, Addr_IRQ
                LDR     PC, Addr_FIQ
		ENDMOD	

;---------------------------------------------------------------
; ?BOOT
;---------------------------------------------------------------
HANDLER  	MACRO HandlerLabel, HandleLabel
HandlerLabel:
	        SUB	  sp,sp,#4        ;decrement sp(to store jump address)
	        STMFD	  sp!,{r0}        ;PUSH the work register to stack(lr does't push because it return to original address)
	        LDR       r0,=HandleLabel;load the address of HandleXXX to r0
	        LDR       r0,[r0]         ;load the contents(service routine start address) of HandleXXX
	        STR       r0,[sp,#4]      ;store the contents(ISR) of HandleXXX to stack
	        LDMFD     sp!,{r0,pc}     ;POP the work register and pc(jump to ISR)
	        ENDM
	        
	        
		PROGRAM	?BOOT
		RSEG	ICODE:CODE:NOROOT(2)
		EXTERN	?cstartup
		CODE32
		PUBLIC  Addr_Reset,Addr_Undefined,Addr_Swi,Addr_Prefetch,Addr_Prefetch,Addr_Dabort,Addr_IRQ,Addr_FIQ
		EXTERN  pISR_Reset, pISR_Undef, pISR_SWI, pISR_Pabort, pISR_Dabort
		EXTERN  pISR_Reserved, pISR_IRQ, pISR_FIQ
		EXTERN  pISR_EXT0		

ResetHandler	
?boot:	


        LDR     r0,=INTMSK
        LDR     r1,=0x003FFFFF  ;all interrupt disable
        STR     r1,[r0]

        ;
        ;Set memory control registers
        ;
        LDR     r0,=SMRDATA
        LDR     r1,=SYSCON                      ;SYSCON Address
        LDR     r3, [r0], #4
        STR     r3, [r1], #0

        LDR     r1,=CLKCON                      ;CLKCON Address
        LDR     r3, [r0], #4
        STR     r3, [r1], #0

        LDR     R0,=SMRDATA1
        LDMIA   R0,{R1-R3}
        LDR     R0,=EXTACON0
        STMIA   R0,{R1-R3}

#ifdef  LOADER
 
        LDR     R0,=LOADER_MAP
        LDMIA   R0,{R1-R11}
        LDR     R0,=ROMCON0
        STMIA   R0,{R1-R11}

		LDR		R0,=0
		LDR		R1,=ROM0_SIZE
		LDR		R2,=SDRAM0_BASE_FOR_LOADER
Relocate:
		LDR		R3,[R0],#4
		STR		R3,[R2],#4
		SUBS	R1,R1,#4
		BNE		Relocate
#endif  

        LDR     R0,=SMRDATA2
        LDMIA   R0,{R1-R11}
        LDR     R0,=ROMCON0
        STMIA   R0,{R1-R11}

        ; Setup IRQ handler
        LDR     r0,=pISR_IRQ       ;This routine is needed
        LDR     r1,=IsrIRQ          ;if there isn't 'subs pc,lr,#4' at 0x18, 0x1c
        STR     r1,[r0]


; ########## Initial critical IO
        ; ...


; ##########  Execute C startup code.
        b           ?cstartup

IsrIRQ
        SUB     sp,sp,#4       ;reserved for PC
        STMFD   sp!,{r8-r9}

        LDR     r9,=INTOSET_IRQ
        LDR     r9,[r9]
        LDR     r8,=pISR_EXT0
        LDR     r8,[r8,r9]
        STR     r8,[sp,#8]
        LDMFD   sp!,{r8-r9,pc}

        ; Put constant table here.
        LTORG
        
SMRDATA:
        DC32 ((SYS_SDM<<31)+(SYS_PD_ID<<26)+(SYS_SFR_SADDR<<16)+(SYS_SRAM_SADDR<<6)+(SYS_CM<<4)+(SYS_WE<<2)+(SYS_CE<<1)+(SYS_SE)) ; SYSCON
        DC32 ((CLK_TAC<<18)+(CLK_R5MUX<<17)+(CLK_R5WAIT<<16)+(CLK_DIVIDING))                                                      ; CLKCON
SMRDATA1
        DC32 ((IO1_TACC<<25)+(IO1_TCOH<<22)+(IO1_TACS<<19)+(IO1_TCOS<<16)+(IO0_TACC<<9)+(IO0_TCOH<<6)+(IO0_TACS<<3)+(IO0_TCOS))  ; EXTACON0
        DC32 ((IO3_TACC<<25)+(IO3_TCOH<<22)+(IO3_TACS<<19)+(IO3_TCOS<<16)+(IO1_TACC<<9)+(IO1_TCOH<<6)+(IO1_TACS<<3)+(IO1_TCOS))  ; EXTACON1
        DC32 ((IO3_BWSCON<<26)+(IO2_BWSCON<<24)+(IO1_BWSCON<<22)+(IO0_BWSCON<<20)+(DR3_BWSCON<<18)+(DR2_BWSCON<<16)+(DR1_BWSCON<<14)+(DR0_BWSCON<<12)+(R5_BWSCON<<10)+(R4_BWSCON<<8)+(R3_BWSCON<<6)+(R2_BWSCON<<4)+(R1_BWSCON<<2)+(R0_BWSCON)) ; EXTDBWTH
SMRDATA2
        DC32 ((R0_NSADDR<<20)+(R0_SADDR<<10)+(R0_TACC<<4)+(R0_TPA<<2)+R0_PMC)    ; ROMCON0
        DC32 ((R1_NSADDR<<20)+(R1_SADDR<<10)+(R1_TACC<<4)+(R1_TPA<<2)+R1_PMC)    ; ROMCON0
        DC32 ((R2_NSADDR<<20)+(R2_SADDR<<10)+(R2_TACC<<4)+(R2_TPA<<2)+R2_PMC)    ; ROMCON0
        DC32 ((R3_NSADDR<<20)+(R3_SADDR<<10)+(R3_TACC<<4)+(R3_TPA<<2)+R3_PMC)    ; ROMCON0
        DC32 ((R4_NSADDR<<20)+(R4_SADDR<<10)+(R4_TACC<<4)+(R4_TPA<<2)+R4_PMC)    ; ROMCON0
        DC32 ((R5_NSADDR<<20)+(R5_SADDR<<10)+(R5_TACC<<4)+(R5_TPA<<2)+R5_PMC)    ; ROMCON0
        DC32 ((DR0_NSADDR<<20)+(DR0_SADDR<<10)+(DR0_TRP<<8)+(DR0_TRC<<7)+(DR0_TCP<<3)+(DR0_TCS<<1)+DR0_EDO)
        DC32 ((DR1_NSADDR<<20)+(DR1_SADDR<<10)+(DR1_TRP<<8)+(DR1_TRC<<7)+(DR0_TCP<<3)+(DR1_TCS<<1)+DR1_EDO)
        DC32 ((DR2_NSADDR<<20)+(DR2_SADDR<<10)+(DR2_TRP<<8)+(DR2_TRC<<7)+(DR0_TCP<<3)+(DR2_TCS<<1)+DR2_EDO)
        DC32 ((DR3_NSADDR<<20)+(DR3_SADDR<<10)+(DR3_TRP<<8)+(DR3_TRC<<7)+(DR0_TCP<<3)+(DR3_TCS<<1)+DR3_EDO)
        DC32 ((REF_CNT<<21)+(REF_TCSR<<20)+(REF_TCHR<<17)+(REF_REN<<16)+(REF_VSF<<15)+REF_SADDR) ; REFEXTCON
 #ifdef LOADER
LOADER_MAP
        DC32 ((0x1f<<20)+(0<<10)+(R0_TACC<<4)+(R0_TPA<<2)+R0_PMC)    ; ROMCON0
        DC32 ((R1_NSADDR<<20)+(R1_SADDR<<10)+(R1_TACC<<4)+(R1_TPA<<2)+R1_PMC)    ; ROMCON0
        DC32 ((R2_NSADDR<<20)+(R2_SADDR<<10)+(R2_TACC<<4)+(R2_TPA<<2)+R2_PMC)    ; ROMCON0
        DC32 ((R3_NSADDR<<20)+(R3_SADDR<<10)+(R3_TACC<<4)+(R3_TPA<<2)+R3_PMC)    ; ROMCON0
        DC32 ((R4_NSADDR<<20)+(R4_SADDR<<10)+(R4_TACC<<4)+(R4_TPA<<2)+R4_PMC)    ; ROMCON0
        DC32 ((R5_NSADDR<<20)+(R5_SADDR<<10)+(R5_TACC<<4)+(R5_TPA<<2)+R5_PMC)    ; ROMCON0
        DC32 ((0x2ff<<20)+(0x100<<10)+(DR0_TRP<<8)+(DR0_TRC<<7)+(DR0_TCP<<3)+(DR0_TCS<<1)+DR0_EDO)
        DC32 ((DR1_NSADDR<<20)+(DR1_SADDR<<10)+(DR1_TRP<<8)+(DR1_TRC<<7)+(DR0_TCP<<3)+(DR1_TCS<<1)+DR1_EDO)
        DC32 ((DR2_NSADDR<<20)+(DR2_SADDR<<10)+(DR2_TRP<<8)+(DR2_TRC<<7)+(DR0_TCP<<3)+(DR2_TCS<<1)+DR2_EDO)
        DC32 ((DR3_NSADDR<<20)+(DR3_SADDR<<10)+(DR3_TRP<<8)+(DR3_TRC<<7)+(DR0_TCP<<3)+(DR3_TCS<<1)+DR3_EDO)
        DC32 ((REF_CNT<<21)+(REF_TCSR<<20)+(REF_TCHR<<17)+(REF_REN<<16)+(REF_VSF<<15)+REF_SADDR) ; REFEXTCON
#endif
SMRDATA_END

                
Addr_Reset      DC32     ResetHandler
Addr_Undefined  DC32     HandlerUndef
Addr_Swi		DC32     HandlerSWI
Addr_Prefetch  	DC32     HandlerPabort
Addr_Dabort     DC32     HandlerDabort
                DC32     0               ; Reserved
Addr_IRQ       	DC32     HandlerIRQ
Addr_FIQ       	DC32     HandlerFIQ


; ************************
; Exception Handlers
; ************************
        
	LTORG 
    HANDLER HandlerFIQ, pISR_FIQ
    HANDLER HandlerIRQ,pISR_IRQ
    HANDLER HandlerUndef,pISR_Undef
    HANDLER HandlerSWI,pISR_SWI
    HANDLER HandlerDabort,pISR_Dabort
    HANDLER HandlerPabort,pISR_Pabort                              
             
		ENDMOD ?boot		; Entry point = ?boot
		
;---------------------------------------------------------------
; ?CSTARTUP
;---------------------------------------------------------------
		PROGRAM	?CSTARTUP

; RTMODEL attributes ensure that
;		RTMODEL "__rt_version", "4"
		RTMODEL "__endian", ENDIAN_MODE
		RTMODEL "__thumb_aware", "enabled"
;		RTMODEL "__cpu_mode", "*"       ; CPU_MODE_NAME
;		RTMODEL "__code_model", "*"	; Match all code models

; Declare segment used with SFE below
#ifdef _ECPLUSPLUS
		RSEG	DIFUNCT(2)
#endif /* _ECPLUSPLUS */

		RSEG	IRQ_STACK:DATA(2)
		RSEG	FIQ_STACK:DATA(2)		
		RSEG	SVC_STACK:DATA:NOROOT(2)
		RSEG	CSTACK:DATA(2)
		RSEG	ICODE:CODE:NOROOT(2)
		PUBLIC	?cstartup
		EXTERN	__segment_init

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
26uuu亚洲综合色欧美| 一本一道久久a久久精品| 国产成人精品午夜视频免费| 成人成人成人在线视频| 91福利国产精品| 日韩免费看网站| 国产精品视频在线看| 亚洲成人动漫在线免费观看| 精品一区二区综合| 一道本成人在线| 精品福利一区二区三区| 亚洲人成精品久久久久久| 青青草97国产精品免费观看无弹窗版| 国产精品综合在线视频| 在线视频一区二区三区| 久久亚洲春色中文字幕久久久| 亚洲欧美另类久久久精品| 免费在线成人网| 91蜜桃在线观看| 久久在线观看免费| 亚洲va天堂va国产va久| 成人午夜av电影| 欧美一级日韩免费不卡| 亚洲欧美一区二区三区孕妇| 精品一二线国产| 欧美丝袜丝nylons| 国产精品私房写真福利视频| 免费在线观看成人| 在线观看91精品国产入口| 久久综合色8888| 五月综合激情婷婷六月色窝| 99精品视频在线观看| 亚洲精品一区二区三区在线观看| 亚洲一区自拍偷拍| 盗摄精品av一区二区三区| 日韩亚洲欧美一区| 洋洋成人永久网站入口| 懂色av一区二区三区免费看| 欧美一区二区三区公司| 亚洲综合色视频| caoporm超碰国产精品| 久久精品一区二区三区不卡牛牛| 日韩不卡免费视频| 欧美视频在线播放| 亚洲男帅同性gay1069| 成人一二三区视频| 国产午夜亚洲精品午夜鲁丝片| 日韩电影一区二区三区四区| 欧美在线观看视频一区二区三区| 欧美激情自拍偷拍| 国产精品羞羞答答xxdd| 欧美mv日韩mv国产网站app| 日韩电影在线看| 欧美日韩和欧美的一区二区| 一区二区三区在线视频播放| 91网站最新地址| 中文字幕五月欧美| 成人激情黄色小说| 国产女主播一区| 国产suv精品一区二区883| 欧美一级视频精品观看| 日韩福利视频导航| 日韩一区二区精品在线观看| 天天色综合成人网| 欧美精品xxxxbbbb| 亚洲成人av资源| 91精品国产全国免费观看| 天天综合色天天| 欧美一级日韩免费不卡| 久久成人久久爱| wwwwxxxxx欧美| 国产一区二区影院| 国产日韩三级在线| av在线一区二区三区| 亚洲免费在线看| 91免费国产在线观看| 亚洲高清不卡在线| 欧美一区二区免费| 韩国女主播成人在线| 久久一二三国产| 成人综合婷婷国产精品久久| 最新日韩av在线| 欧美性受xxxx黑人xyx性爽| 亚洲一区二区三区四区的| 宅男在线国产精品| 九九九精品视频| 国产视频一区在线播放| 99免费精品在线| 一区二区高清免费观看影视大全| 欧美日韩一区二区三区四区五区| 视频一区视频二区中文| 亚洲精品一区二区三区影院| www.欧美日韩国产在线| 一级做a爱片久久| 欧美一区二区在线看| 久久精品国产77777蜜臀| 久久精品欧美一区二区三区麻豆| 成人18视频在线播放| 一区二区三区高清在线| 日韩一区二区免费高清| 成人黄色一级视频| 亚洲午夜激情av| 日韩美女视频在线| av爱爱亚洲一区| 午夜一区二区三区在线观看| 欧美成人三级电影在线| 成人黄色在线视频| 午夜精品久久久久久久久久 | 亚洲六月丁香色婷婷综合久久| 欧洲在线/亚洲| 国产美女在线观看一区| 樱桃国产成人精品视频| 日韩美女一区二区三区| 91视视频在线观看入口直接观看www | 肉肉av福利一精品导航| 亚洲精品一线二线三线| 日本黄色一区二区| 国产综合色在线| 亚洲综合另类小说| 久久午夜国产精品| 在线影院国内精品| 精品一区二区三区免费毛片爱| 成人免费一区二区三区在线观看| 欧美精品乱码久久久久久| 国产69精品久久99不卡| 天使萌一区二区三区免费观看| 久久久精品2019中文字幕之3| 色狠狠桃花综合| 国产一区二区三区精品视频| 亚洲综合精品自拍| 国产精品网站导航| 日韩免费电影网站| 欧美日韩一区二区欧美激情| 成人开心网精品视频| 久久99精品国产麻豆不卡| 亚洲自拍另类综合| 国产精品日韩成人| 欧美电影精品一区二区| 欧洲激情一区二区| 粉嫩嫩av羞羞动漫久久久| 久久国产人妖系列| 亚洲成人福利片| 亚洲三级在线看| 久久久久久一级片| 欧美一级片在线| 在线区一区二视频| 成人精品高清在线| 国精产品一区一区三区mba视频| 石原莉奈在线亚洲三区| 亚洲精品视频一区| 欧美激情一区二区三区全黄| 精品第一国产综合精品aⅴ| 欧美日韩国产综合草草| 色噜噜久久综合| av网站免费线看精品| 国产成人av电影在线播放| 激情六月婷婷综合| 男人的天堂久久精品| 亚洲成av人综合在线观看| 一级日本不卡的影视| 亚洲免费在线观看| 最新欧美精品一区二区三区| 中文字幕av不卡| 国产亚洲人成网站| 久久综合精品国产一区二区三区| 欧美一级一级性生活免费录像| 欧美日韩不卡一区二区| 欧美视频一区二区在线观看| 色综合久久久久| 91麻豆免费看片| 91麻豆国产精品久久| 一本久久a久久精品亚洲| 99视频热这里只有精品免费| av不卡一区二区三区| 99r国产精品| 99精品久久99久久久久| 97成人超碰视| 日本丶国产丶欧美色综合| 91精品1区2区| 欧美性猛片aaaaaaa做受| 欧美性受xxxx| 欧美日韩亚洲综合一区二区三区| 欧美视频在线观看一区| 欧美日韩国产首页在线观看| 欧美精品粉嫩高潮一区二区| 欧美一级艳片视频免费观看| 日韩精品在线网站| 国产亚洲精久久久久久| 国产精品丝袜黑色高跟| 亚洲乱码日产精品bd| 亚洲一区二区三区中文字幕在线| 亚洲国产精品一区二区久久恐怖片 | 风间由美一区二区av101| 高清不卡一区二区| 成人av在线资源| 91一区二区在线观看| 欧美日韩在线免费视频| 欧美一区二区三区免费| 久久久久久久久久久久久久久99 | 色94色欧美sute亚洲线路一久|