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

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

?? 44binit.s

?? led,key,i2c,uart,adc,rtc,wdt測SHI 文件代碼
?? S
?? 第 1 頁 / 共 2 頁
字號:
; *******************************************************
; * NAME    : 44BINIT.S									*
; * Description:										*
; *	C start up codes									*
; *	Configure memory, Initialize ISR ,stacks			*
; *	Initialize C-variables								*
; *	Fill zeros into zero-initialized C-variables		*
; *******************************************************
 
    INCLUDE option.s
    INCLUDE memcfg.s

;Memory Area
;GCS0 FLASH 1m*16bits=2M BYTE----------------[0x00000000-0x001FFFFF]
;GCS6 SDRAM 4banks*1m*16bits=8M BYTE---------[0x0C000000-0x0C7FFFFF]

;APP    RAM=0xc000000-0xc7effff 
;44BMON RAM=0xc7f0000-0xc7fffff
;STACK	   =0xc7ffa00		   

;Interrupt Control
INTPND	    EQU	0x01e00004
INTMOD	    EQU	0x01e00008
INTMSK	    EQU	0x01e0000c
I_ISPR	    EQU	0x01e00020
I_CMST	    EQU	0x01e0001c

;Watchdog timer
WTCON	    EQU	0x01d30000

;Clock Controller
PLLCON	    EQU	0x01d80000
CLKCON	    EQU	0x01d80004
LOCKTIME    EQU	0x01d8000c
	
;Memory Controller
REFRESH	    EQU 0x01c80024

;BDMA destination register
BDIDES0     EQU 0x1f80008
BDIDES1     EQU 0x1f80028

;Pre-defined constants
USERMODE    EQU	0x10
FIQMODE	    EQU	0x11
IRQMODE	    EQU	0x12
SVCMODE	    EQU	0x13
ABORTMODE   EQU	0x17
UNDEFMODE   EQU	0x1b
MODEMASK    EQU	0x1f
NOINT	    EQU	0xc0

;check if tasm.exe is used.
    GBLL    THUMBCODE
    [ {CONFIG} = 16	
THUMBCODE SETL	{TRUE}
    CODE32
    |   
THUMBCODE SETL	{FALSE}
    ]

    [ THUMBCODE
    CODE32   ;for start-up code for Thumb mode
    ]

    MACRO
$HandlerLabel HANDLER $HandleLabel

$HandlerLabel
    sub	    sp,sp,#4	    	;decrement sp(to store jump address)
    stmfd   sp!,{r0}	    	;PUSH the work register to stack(lr does not 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)
    MEND

    IMPORT	|Image$$RO$$Limit|  ; End of ROM code (=start of ROM data)
    IMPORT	|Image$$RW$$Base|   ; Base of RAM to initialise
    IMPORT	|Image$$ZI$$Base|   ; Base and limit of area
    IMPORT	|Image$$ZI$$Limit|  ; to zero initialise

    IMPORT  Main    ; The main entry of mon program 

    AREA    Init,CODE,READONLY

    ENTRY 
    b ResetHandler  ;for debug
    b HandlerUndef  ;handlerUndef
    b HandlerSWI    ;SWI interrupt handler
    b HandlerPabort ;handlerPAbort
    b HandlerDabort ;handlerDAbort
    b .		    ;handlerReserved
    b HandlerIRQ
    b HandlerFIQ
	;***IMPORTANT NOTE***
	;If the H/W vectored interrutp mode is enabled, The above two instructions should
	;be changed like below, to work-around with H/W bug of S3C44B0X interrupt controller. 
	; b HandlerIRQ  ->  subs pc,lr,#4
	; b HandlerIRQ  ->  subs pc,lr,#4

VECTOR_BRANCH
    ldr pc,=HandlerEINT0    ;mGA    H/W interrupt vector table
    ldr pc,=HandlerEINT1    ;	
    ldr pc,=HandlerEINT2    ;
    ldr pc,=HandlerEINT3    ;
    ldr pc,=HandlerEINT4567 ;
    ldr pc,=HandlerTICK	    ;mGA
    b .
    b .
    ldr pc,=HandlerZDMA0    ;mGB
    ldr pc,=HandlerZDMA1    ;
    ldr pc,=HandlerBDMA0    ;
    ldr pc,=HandlerBDMA1    ;
    ldr pc,=HandlerWDT	    ;
    ldr pc,=HandlerUERR01   ;mGB
    b .
    b .
    ldr pc,=HandlerTIMER0   ;mGC
    ldr pc,=HandlerTIMER1   ;
    ldr pc,=HandlerTIMER2   ;
    ldr pc,=HandlerTIMER3   ;
    ldr pc,=HandlerTIMER4   ;
    ldr pc,=HandlerTIMER5   ;mGC
    b .
    b .
    ldr pc,=HandlerURXD0    ;mGD
    ldr pc,=HandlerURXD1    ;
    ldr pc,=HandlerIIC	    ;
    ldr pc,=HandlerSIO	    ;
    ldr pc,=HandlerUTXD0    ;
    ldr pc,=HandlerUTXD1    ;mGD
    b .
    b .
    ldr pc,=HandlerRTC	    ;mGKA
    b .						;
    b .						;
    b .						;
    b .						;
    b .						;mGKA
    b .
    b .
    ldr pc,=HandlerADC	    ;mGKB
    b .						;
    b .						;
    b .						;
    b .						;
    b .						;mGKB
    b .
    b .
;0xe0=EnterPWDN
    ldr pc,=EnterPWDN

    LTORG	

HandlerFIQ		HANDLER HandleFIQ
HandlerIRQ		HANDLER HandleIRQ
HandlerUndef	HANDLER HandleUndef
HandlerSWI		HANDLER HandleSWI
HandlerDabort	HANDLER HandleDabort
HandlerPabort	HANDLER HandlePabort

HandlerADC		HANDLER HandleADC
HandlerRTC		HANDLER HandleRTC
HandlerUTXD1	HANDLER HandleUTXD1
HandlerUTXD0	HANDLER HandleUTXD0
HandlerSIO		HANDLER HandleSIO
HandlerIIC		HANDLER HandleIIC
HandlerURXD1	HANDLER HandleURXD1
HandlerURXD0	HANDLER HandleURXD0
HandlerTIMER5	HANDLER HandleTIMER5
HandlerTIMER4	HANDLER HandleTIMER4
HandlerTIMER3	HANDLER HandleTIMER3
HandlerTIMER2	HANDLER HandleTIMER2
HandlerTIMER1	HANDLER HandleTIMER1
HandlerTIMER0	HANDLER HandleTIMER0
HandlerUERR01	HANDLER HandleUERR01
HandlerWDT		HANDLER HandleWDT
HandlerBDMA1	HANDLER HandleBDMA1
HandlerBDMA0	HANDLER HandleBDMA0
HandlerZDMA1	HANDLER HandleZDMA1
HandlerZDMA0	HANDLER HandleZDMA0
HandlerTICK		HANDLER HandleTICK
HandlerEINT4567	HANDLER HandleEINT4567
HandlerEINT3	HANDLER HandleEINT3
HandlerEINT2	HANDLER HandleEINT2
HandlerEINT1	HANDLER HandleEINT1
HandlerEINT0	HANDLER HandleEINT0


;One of the following two routines can be used for non-vectored interrupt.

IsrIRQ	;using I_ISPR register.
    sub	    sp,sp,#4       ;reserved for PC
    stmfd   sp!,{r8-r9}   

	;IMPORTANT CAUTION
	;if I_ISPC is not used properly, I_ISPR can be 0 in this routine.

    ldr	    r9,=I_ISPR
    ldr	    r9,[r9]

	cmp		r9, #0x0	;If the IDLE mode work-around is used,
						;r9 may be 0 sometimes.
	beq		%F2

    mov	    r8,#0x0
0
    movs    r9,r9,lsr #1
    bcs	    %F1
    add	    r8,r8,#4
    b	    %B0

1
    ldr	    r9,=HandleADC
    add	    r9,r9,r8
    ldr	    r9,[r9]
    str	    r9,[sp,#8]
    ldmfd   sp!,{r8-r9,pc}

2
	ldmfd	sp!,{r8-r9}
	add		sp,sp,#4
	subs	pc,lr,#4

;****************************************************
;*	START											*
;****************************************************
ResetHandler
    ldr	    r0,=WTCON	    ;watch dog disable 
    ldr	    r1,=0x0 		
    str	    r1,[r0]

    ldr	    r0,=INTMSK
    ldr	    r1,=0x07ffffff  ;all interrupt disable
    str	    r1,[r0]

    ;****************************************************
    ;*	Set clock control registers						*
    ;****************************************************
    ldr	r0,=LOCKTIME
    ldr	r1,=0xfff
    str	r1,[r0]

    [ PLLONSTART
	ldr	r0,=PLLCON			;temporary setting of PLL
	ldr	r1,=((M_DIV<<12)+(P_DIV<<4)+S_DIV)	;Fin=10MHz,Fout=40MHz
	str	r1,[r0]
    ]

    ldr	    r0,=CLKCON		 
    ldr	    r1,=0x7ff8	    ;All unit block CLK enable	
    str	    r1,[r0]

    ;****************************************
    ;*  change BDMACON reset value for BDMA *   
    ;****************************************
    ldr     r0,=BDIDES0       
    ldr     r1,=0x40000000   ;BDIDESn reset value should be 0x40000000	 
    str     r1,[r0]

    ldr     r0,=BDIDES1      
    ldr     r1,=0x40000000   ;BDIDESn reset value should be 0x40000000	 
    str     r1,[r0]

    ;****************************************************
    ;*	Set memory control registers					* 	
    ;****************************************************
    ldr	    r0,=SMRDATA
    ldmia   r0,{r1-r11}
		
    ldr	    r0,=0x01c80000  ;BWSCON Address
    stmia   r0,{r1-r11}
;MRSR register must not be reconfigured while the code is running on SDRAM

    ;****************************************************
    ;*	Initialize stacks								* 
    ;****************************************************
    ldr	    sp, =SVCStack	;Why?
    bl	    InitStacks

    ;****************************************************
    ;*	Setup IRQ handler								*
    ;****************************************************
    ldr	    r0,=HandleIRQ		;This routine is needed
    ldr	    r1,=IsrIRQ			;if there is not 'subs pc,lr,#4' at 0x18, 0x1c
    str	    r1,[r0]

    ;********************************************************
    ;*	Copy and paste RW data/zero initialized data	    *
    ;********************************************************
    LDR	    r0, =|Image$$RO$$Limit|	; Get pointer to ROM data
    LDR	    r1, =|Image$$RW$$Base|	; and RAM copy
    LDR	    r3, =|Image$$ZI$$Base|	
	;Zero init base => top of initialised data
			
    CMP	    r0, r1	    ; Check that they are different
    BEQ	    %F1
0		
    CMP	    r1, r3	    ; Copy init data
    LDRCC   r2, [r0], #4    ;--> LDRCC r2, [r0] + ADD r0, r0, #4		 
    STRCC   r2, [r1], #4    ;--> STRCC r2, [r1] + ADD r1, r1, #4
    BCC	    %B0
1		
    LDR	    r1, =|Image$$ZI$$Limit| ; Top of zero init segment
    MOV	    r2, #0
2		
    CMP	    r3, r1	    ; Zero init
    STRCC   r2, [r3], #4
    BCC	    %B2

    [ :LNOT:THUMBCODE
	BL	Main	    ;Do not use main() because ......
	B	.						
    ]

    [ THUMBCODE		    ;for start-up code for Thumb mode
	orr     lr,pc,#1
	bx      lr
	CODE16
	bl      Main	    ;Do not use main() because ......
	b       .
	CODE32
    ]

;****************************************************
;*	The function for initializing stack				*
;****************************************************
InitStacks
	;Do not use DRAM,such as stmfd,ldmfd......
	;SVCstack is initialized before
	;Under toolkit ver 2.50, 'msr cpsr,r1' can be used instead of 'msr cpsr_cxsf,r1'

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品国产三级国产专播品爱网| 欧美日韩免费视频| 日韩视频国产视频| 91精品福利视频| 91麻豆精品一区二区三区| 成人免费看黄yyy456| 国产成人自拍高清视频在线免费播放| 国产一区二区三区在线观看免费| 久久国内精品视频| 国产一区在线看| 国产黑丝在线一区二区三区| av动漫一区二区| 在线视频国内一区二区| 欧美在线999| 91麻豆精品91久久久久久清纯| 91精品国产一区二区| 精品国产自在久精品国产| 欧美成人艳星乳罩| 欧美激情综合五月色丁香| 日韩毛片高清在线播放| 亚洲国产精品视频| 久热成人在线视频| 成人午夜电影久久影院| 99国内精品久久| 欧美一区二区三区在| 国产日韩欧美麻豆| 亚洲国产精品影院| 国产乱码字幕精品高清av| 成人精品一区二区三区四区| 欧美三区在线观看| 2014亚洲片线观看视频免费| 亚洲日本乱码在线观看| 麻豆成人久久精品二区三区小说| 国产91精品免费| 欧美综合一区二区| 久久久欧美精品sm网站| 一区二区三区毛片| 国产一区二区不卡老阿姨| 91免费国产视频网站| 日韩三级电影网址| 一区二区三区四区在线播放| 九九精品视频在线看| 91国偷自产一区二区三区观看 | 成人丝袜18视频在线观看| 99久久99久久精品免费看蜜桃| 日韩一级在线观看| 亚洲免费在线观看视频| 国产精品一区免费视频| 91麻豆精品国产91| 亚洲一级在线观看| 成人av资源站| 久久综合丝袜日本网| 视频一区欧美日韩| 欧美中文字幕亚洲一区二区va在线 | 欧美丝袜丝交足nylons图片| 国产视频一区二区三区在线观看| 偷拍自拍另类欧美| 日本乱人伦aⅴ精品| 中文字幕高清一区| 国产一区二区网址| 日韩视频不卡中文| 免费成人av在线播放| 欧美日韩国产综合视频在线观看| 亚洲人快播电影网| av一区二区三区在线| 欧美韩日一区二区三区四区| 韩国毛片一区二区三区| 日韩欧美激情四射| 久久精品国产久精国产爱| 欧美一区二区三区视频免费| 亚洲一区在线视频| 91论坛在线播放| 亚洲欧美日韩国产综合在线| 94色蜜桃网一区二区三区| 亚洲欧洲日韩一区二区三区| 国产白丝网站精品污在线入口| 久久嫩草精品久久久精品 | 久久精品人人做人人爽97| 久久99久久99| 久久久久久久久岛国免费| 国产乱人伦偷精品视频免下载| 亚洲自拍另类综合| 欧美日韩精品欧美日韩精品一| 中文字幕中文字幕一区| 成人国产一区二区三区精品| 最新高清无码专区| 欧洲色大大久久| 一区二区三区欧美| 91精品福利在线一区二区三区 | kk眼镜猥琐国模调教系列一区二区 | 欧美电影免费观看完整版| 蜜桃av噜噜一区| 国产视频一区二区在线| 91香蕉视频黄| 国产欧美中文在线| 国产欧美日产一区| 国产美女娇喘av呻吟久久| 国产精品美女久久久久久久久久久| 国产成人自拍网| 中文字幕五月欧美| 欧美日韩精品一区二区天天拍小说 | 亚洲精品免费播放| 日韩网站在线看片你懂的| 国产精品一区二区黑丝| 亚洲精品国产一区二区三区四区在线| 欧美人牲a欧美精品| 国产一区在线视频| 亚洲综合区在线| 亚洲精品在线电影| 色婷婷av一区二区三区大白胸 | 亚洲与欧洲av电影| 精品对白一区国产伦| av一区二区三区在线| 首页国产欧美日韩丝袜| 国产欧美日韩视频一区二区| 欧美日韩午夜在线| 国产精品18久久久久久久网站| 一区二区三区在线免费视频| 久久日韩精品一区二区五区| 91极品视觉盛宴| 成人美女视频在线观看| 天天操天天色综合| 亚洲视频一区在线观看| 日韩亚洲欧美综合| 欧美综合在线视频| 99视频一区二区| 国产精品影视在线| 日韩电影在线观看电影| 最好看的中文字幕久久| 2019国产精品| 日韩女优视频免费观看| 欧美日韩一级视频| 久久久精品欧美丰满| 欧美色网一区二区| 91免费观看国产| 国产精品自拍一区| 久久精品国产77777蜜臀| 亚洲高清视频在线| 亚洲伊人伊色伊影伊综合网| 中文字幕一区二区三区在线不卡 | 国产一区二区久久| 日本 国产 欧美色综合| 亚洲国产精品影院| 亚洲影视在线观看| 亚洲一区二区精品视频| 亚洲欧美激情视频在线观看一区二区三区 | 欧美日韩国产精品成人| 欧美性xxxxx极品少妇| 色婷婷国产精品综合在线观看| 91亚洲国产成人精品一区二区三| 高清国产午夜精品久久久久久| 国产一区欧美二区| 国产一区二三区好的| 国产一区二区三区免费播放| 精品写真视频在线观看| 久久av中文字幕片| 国产一区二区三区黄视频 | 五月婷婷激情综合网| 亚洲最新视频在线观看| 一区二区三区蜜桃| 亚州成人在线电影| 日本不卡视频在线观看| 男女激情视频一区| 国产综合久久久久久鬼色 | 欧美人与性动xxxx| 在线综合+亚洲+欧美中文字幕| 日韩一级欧美一级| 日韩精品专区在线| 久久久精品免费网站| 亚洲欧美日韩一区二区三区在线观看| 亚洲人吸女人奶水| 亚洲福利一区二区| 精彩视频一区二区| 福利电影一区二区| 91影视在线播放| 欧美日韩免费观看一区三区| 精品日韩一区二区| 国产精品久久久久影院| 亚洲国产日韩a在线播放性色| 奇米777欧美一区二区| 成人网在线播放| 欧美日韩国产综合久久| 久久精品综合网| 亚洲va欧美va天堂v国产综合| 捆绑变态av一区二区三区| 成人视屏免费看| 欧美丰满一区二区免费视频 | 亚洲免费观看高清完整版在线观看 | 一区二区三区精品视频在线| 日韩精品一卡二卡三卡四卡无卡| 国产成人福利片| 欧美人狂配大交3d怪物一区 | 在线日韩一区二区| 欧美v日韩v国产v| 亚洲欧美色一区| 国产在线不卡一区| 欧美午夜精品免费| 久久九九99视频| 日韩高清欧美激情| 99re热视频精品|