亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
亚洲国产精品av| 欧美精彩视频一区二区三区| 一本色道久久综合狠狠躁的推荐 | 亚洲色图在线看| 国产日韩欧美电影| 欧美韩国日本一区| 国产精品国产a级| 综合久久久久久| 亚洲一区在线播放| 亚洲一区二区在线免费观看视频| 亚洲一二三四在线| 亚洲二区在线观看| 美洲天堂一区二卡三卡四卡视频| 久久99热国产| 国产91精品久久久久久久网曝门 | 午夜日韩在线电影| 日韩精品五月天| 国产在线视频一区二区| 国产精品综合网| thepron国产精品| 欧美日韩1234| 久久久久9999亚洲精品| 国产欧美中文在线| 综合欧美亚洲日本| 亚洲午夜久久久| 国产一区二区三区久久悠悠色av | 亚洲午夜精品在线| 久国产精品韩国三级视频| 丁香另类激情小说| 欧美色倩网站大全免费| 欧美xxxxx牲另类人与| 亚洲精品videosex极品| 一区二区三区在线不卡| 久久精品久久久精品美女| 韩国精品在线观看| 在线观看91精品国产入口| 51精品国自产在线| 日韩精品专区在线| 午夜精品123| 欧美一区二区网站| 亚洲狠狠丁香婷婷综合久久久| 国产精品一色哟哟哟| 亚洲精品一区在线观看| 香蕉久久一区二区不卡无毒影院| 精品一区二区三区免费视频| 精品99久久久久久| 亚洲精品国产视频| 国内精品久久久久影院薰衣草 | 欧美欧美欧美欧美首页| 欧美精品一区二区在线播放| 一区二区三区四区不卡在线| 国产99久久久国产精品| 欧美精品色综合| √…a在线天堂一区| 国模一区二区三区白浆| 欧美日韩久久一区| 亚洲免费在线视频一区 二区| 韩国女主播成人在线观看| 欧美四级电影网| 亚洲人妖av一区二区| 国产精品1024| 亚洲精品一区在线观看| 七七婷婷婷婷精品国产| 欧美性生活久久| 亚洲电影第三页| 欧美日韩一区二区三区视频| 亚洲少妇30p| 色综合一区二区| 中文字幕一区二区三区四区 | 精品久久久网站| 麻豆专区一区二区三区四区五区| 欧美久久久久免费| 亚洲一级二级三级| 精品视频免费在线| 亚洲成av人片一区二区| 色欧美日韩亚洲| 亚洲综合在线第一页| 91麻豆免费在线观看| 亚洲黄色录像片| 欧美疯狂做受xxxx富婆| 天堂精品中文字幕在线| 欧美乱妇23p| 久久99久久99精品免视看婷婷 | 成人美女视频在线观看| 久久久久久电影| 成人毛片在线观看| 亚洲六月丁香色婷婷综合久久 | 亚洲欧美日本韩国| 在线视频一区二区免费| 亚洲国产另类av| 欧美男生操女生| 麻豆久久一区二区| 国产欧美日韩在线视频| 国产老肥熟一区二区三区| 国产亚洲一区二区三区在线观看| 成人av高清在线| 一区二区国产盗摄色噜噜| 欧美日韩亚洲综合一区二区三区| 日本欧美久久久久免费播放网| 精品国产伦一区二区三区观看方式 | 成人免费视频视频| 亚洲精品国产高清久久伦理二区| 91精品国产欧美一区二区成人| 久久se精品一区精品二区| 国产精品午夜春色av| 91老师国产黑色丝袜在线| 日韩精品乱码av一区二区| 久久一区二区三区国产精品| 91麻豆国产福利精品| 免费观看30秒视频久久| 国产精品久久国产精麻豆99网站| 精品视频在线免费| 激情小说欧美图片| 亚洲男女一区二区三区| 日韩免费观看高清完整版在线观看| 顶级嫩模精品视频在线看| 亚洲aⅴ怡春院| 中文av一区二区| 日韩一卡二卡三卡| 成人av在线网| 精品在线亚洲视频| 一区二区三区欧美激情| 久久久精品中文字幕麻豆发布| 欧美日韩国产影片| av一区二区不卡| 国产制服丝袜一区| 亚洲第一久久影院| 国产精品久久久久一区| 欧美一级二级三级蜜桃| 99精品一区二区三区| 国产中文字幕一区| 秋霞午夜av一区二区三区| 亚洲精品成a人| 亚洲欧美日韩久久| 中文字幕av一区二区三区免费看 | 久久精品国产99国产| 亚洲一区二区免费视频| 最新不卡av在线| 国产精品无遮挡| 亚洲国产成人私人影院tom | 樱花草国产18久久久久| 国产精品乱码人人做人人爱| 久久久久久久久久看片| 欧美电影免费提供在线观看| 91精品国产高清一区二区三区| 欧美日韩电影一区| 欧美精品一二三| 在线不卡中文字幕| 欧美精品自拍偷拍| 欧美二区三区的天堂| 欧美疯狂做受xxxx富婆| 欧美日本一区二区三区| 欧美日本精品一区二区三区| 欧美精品123区| 欧美va亚洲va香蕉在线| 欧美一区二区日韩| 日韩欧美国产精品一区| 日韩精品一区二区三区中文精品| 日韩欧美区一区二| 日韩精品资源二区在线| 精品少妇一区二区三区在线视频 | 春色校园综合激情亚洲| 国内欧美视频一区二区| 国内精品写真在线观看| 国产福利一区二区三区视频在线| 成人h动漫精品一区二区| 成人黄色在线看| 一本大道久久a久久综合| 91黄色免费观看| 欧美精品一级二级| 日韩一区二区三区在线| 日韩欧美一二三| 国产日产精品1区| 亚洲色图丝袜美腿| 亚洲综合视频在线观看| 视频一区二区三区中文字幕| 久久精品国产澳门| 成人h动漫精品| 777xxx欧美| 国产精品初高中害羞小美女文| 亚洲裸体xxx| 韩国毛片一区二区三区| 99久久伊人网影院| 欧美美女一区二区| 国产亚洲人成网站| 亚洲免费观看在线视频| 日韩精品电影一区亚洲| 国产精品69久久久久水密桃| 欧洲亚洲精品在线| 欧美一区二区三区免费在线看 | 久久精品网站免费观看| 亚洲色图视频网站| 美女国产一区二区| 不卡的av电影在线观看| 欧美一级日韩不卡播放免费| 国产精品理伦片| 激情文学综合丁香| 欧美少妇bbb| 中文字幕二三区不卡| 奇米777欧美一区二区|