亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
久久国产精品免费| 91麻豆精品视频| 成人一区二区三区视频在线观看| 99视频精品免费视频| 91精品国产日韩91久久久久久| 中文字幕国产一区| 伦理电影国产精品| 欧美丰满一区二区免费视频| 国产精品久久久久久户外露出| 理论片日本一区| 欧美男女性生活在线直播观看| 国产精品电影院| 国产九色sp调教91| 欧美精品一区二区久久久| 五月天激情小说综合| 在线中文字幕一区二区| 中文字幕在线视频一区| 国产精品69毛片高清亚洲| 日韩视频在线永久播放| 性欧美疯狂xxxxbbbb| 日本韩国欧美一区| 亚洲精品欧美综合四区| 91小视频免费观看| √…a在线天堂一区| va亚洲va日韩不卡在线观看| 久久精品一区蜜桃臀影院| 久久电影网电视剧免费观看| 制服丝袜激情欧洲亚洲| 日韩不卡免费视频| 日韩视频一区在线观看| 秋霞电影网一区二区| 欧美一区二区在线看| 免费美女久久99| 日韩欧美一级精品久久| 狠狠色综合日日| 久久久综合精品| 大胆欧美人体老妇| 国产精品久久久久影视| av一区二区三区四区| 伊人开心综合网| 精品视频一区二区不卡| 视频在线观看一区| 日韩精品专区在线影院观看| 国内精品久久久久影院一蜜桃| 久久午夜色播影院免费高清| 国产999精品久久久久久| 国产精品久久精品日日| 日本久久电影网| 日本成人在线一区| 久久久91精品国产一区二区精品| 国产91丝袜在线18| 一区二区在线电影| 欧美一二三在线| 国产成人激情av| 亚洲欧美日韩小说| 欧美一区二区美女| 岛国一区二区三区| 婷婷综合五月天| 久久精品水蜜桃av综合天堂| 成人免费视频视频| 午夜精品一区在线观看| 国产亚洲人成网站| 欧美无砖砖区免费| 紧缚捆绑精品一区二区| 日韩一区欧美一区| 欧美一二三区在线| 99热这里都是精品| 日本中文字幕一区二区视频 | 精品成人佐山爱一区二区| 国产成人午夜精品影院观看视频| 亚洲色图欧美偷拍| 日韩欧美国产精品一区| 91免费版在线| 狠狠色丁香婷综合久久| 亚洲美女一区二区三区| 精品少妇一区二区三区免费观看| 99久久精品免费看| 久久99精品国产.久久久久久 | 欧美国产精品久久| 欧美高清视频www夜色资源网| 国产成人免费视| 日韩电影在线观看一区| 中文字幕一区二区三区在线播放 | 激情综合网最新| 一区二区三区加勒比av| 久久亚洲影视婷婷| 欧美美女一区二区| 色综合 综合色| 成人一区二区视频| 国产福利一区在线| 久热成人在线视频| 亚洲成a人在线观看| 亚洲婷婷综合久久一本伊一区| 精品日韩一区二区三区免费视频| 在线观看日韩电影| 91小视频免费观看| 波多野结衣精品在线| 国产一区二区不卡| 久久精品国产精品亚洲综合| 亚洲一区日韩精品中文字幕| 日本一区二区三区视频视频| 2欧美一区二区三区在线观看视频| 欧美日韩一二区| 欧美在线观看你懂的| 99国产麻豆精品| www.亚洲色图| 成人黄动漫网站免费app| 国产福利电影一区二区三区| 精品一区二区三区影院在线午夜| 日韩精品欧美成人高清一区二区| 一级做a爱片久久| 亚洲日本va午夜在线电影| 国产精品三级视频| 国产精品婷婷午夜在线观看| 久久久99精品免费观看不卡| 337p日本欧洲亚洲大胆精品 | 国产一区二区三区在线观看精品 | 午夜精彩视频在线观看不卡| 一区二区三区免费看视频| 一区二区三区成人| 亚洲国产一区二区a毛片| 亚洲一区二区精品视频| 日日夜夜一区二区| 美女国产一区二区三区| 久久成人久久鬼色| 国产成人免费在线视频| 成人美女在线观看| 日本精品一级二级| 制服丝袜在线91| 久久久不卡网国产精品一区| 中文字幕成人av| 亚洲一区二区欧美日韩 | 一区二区三区四区在线免费观看| 亚洲三级电影网站| 亚洲chinese男男1069| 精品在线免费视频| 成人av网站在线| 欧美日韩卡一卡二| 久久综合色之久久综合| 国产精品嫩草影院com| 亚洲欧美日韩中文播放| 日本免费新一区视频| 蓝色福利精品导航| av亚洲精华国产精华精华| 欧美午夜精品久久久久久孕妇 | 国产永久精品大片wwwapp| 处破女av一区二区| 欧美性一区二区| 久久亚洲一级片| 亚洲一区二区三区国产| 国产乱理伦片在线观看夜一区| 99久久99久久久精品齐齐| 91精品久久久久久久91蜜桃| 国产精品情趣视频| 美女一区二区视频| 色综合亚洲欧洲| 久久久精品黄色| 首页综合国产亚洲丝袜| 成人久久视频在线观看| 欧美一二三区在线观看| 亚洲黄色在线视频| 国产一区二区不卡在线| 欧美高清dvd| 亚洲综合免费观看高清完整版在线| 老色鬼精品视频在线观看播放| 色综合激情五月| 国产女主播一区| 免费在线观看精品| 欧美午夜在线一二页| 亚洲欧洲美洲综合色网| 国产一二三精品| 在线播放国产精品二区一二区四区 | 全国精品久久少妇| 欧洲一区在线观看| 中文字幕成人av| 国内一区二区在线| 欧美一区二区精美| 天堂资源在线中文精品| 91色.com| 亚洲蜜臀av乱码久久精品| 国产精品一区二区不卡| 日韩一区二区不卡| 日韩中文字幕av电影| 在线观看精品一区| 亚洲精选在线视频| 97精品视频在线观看自产线路二| 久久久噜噜噜久久中文字幕色伊伊 | jlzzjlzz国产精品久久| 久久久激情视频| 国产福利91精品一区| 精品三级在线看| 精品一区二区三区免费毛片爱| 欧美日韩三级一区| 性欧美疯狂xxxxbbbb| 精品视频1区2区3区| 亚洲图片欧美视频| 欧美日本在线视频| 日韩电影在线免费看| 欧美一区二区三区男人的天堂| 日韩二区三区四区|