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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? init44b0.s

?? 這是一個(gè)基于ARM44B0X的串口實(shí)驗(yàn)程序.
?? S
字號(hào):
; *******************************************************
; * NAME    : INIT44B0.S								*
; * Version : 20.April.2002								*
; * Description:										*
; *	C start up codes									*
; *	Configure memory, Initialize ISR ,stacks			*
; *	Initialize C-variables								*
; *	Fill zeros into zero-initialized C-variables		*
; *******************************************************

    GET option.a
    GET memcfg.a


;Memory Area
;GCS6 64M 16bit(16MB) DRAM/SDRAM(0xc000000-0xcffffff)
;APP    RAM=0xc000000~0xcfeffff 
;44BMON RAM=0xcff0000-0xcffffff
;STACK	   =0xcfffa00		   

;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



    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
    
    
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		;Enter POWER down Mode.
    
 
	 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 isn't 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=4MHz,Fout=60MHz
	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-r13}
    ldr	    r0,=0x01c80000  ;BWSCON Address
    stmia   r0,{r1-r13}
    ;****************************************************
    ;*	Initialize stacks								* 
    ;****************************************************
    ldr	    sp, =SVCStack	;Why?
    bl	    InitStacks
    ;****************************************************
    ;*	Setup IRQ handler								*
    ;****************************************************
    ldr	    r0,=HandleIRQ		;This routine is needed
    ldr	    r1,=IsrIRQ			;if there isn't '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


	B	Main	    ;Don't use main() because ......




;****************************************************
;*	The function for initializing stack				*
;****************************************************
InitStacks
	;Don't 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'

    mrs	    r0,cpsr
    bic	    r0,r0,#MODEMASK
    orr	    r1,r0,#UNDEFMODE|NOINT
    msr	    cpsr_cxsf,r1		;UndefMode
    ldr	    sp,=UndefStack
	
    orr	    r1,r0,#ABORTMODE|NOINT
    msr	    cpsr_cxsf,r1 	    	;AbortMode
    ldr	    sp,=AbortStack

    orr	    r1,r0,#IRQMODE|NOINT
    msr	    cpsr_cxsf,r1 	    	;IRQMode
    ldr	    sp,=IRQStack
	
    orr	    r1,r0,#FIQMODE|NOINT
    msr	    cpsr_cxsf,r1 	    	;FIQMode
    ldr	    sp,=FIQStack

    bic	    r0,r0,#MODEMASK|NOINT
    orr	    r1,r0,#SVCMODE
    msr	    cpsr_cxsf,r1 	    	;SVCMode
    ldr	    sp,=SVCStack

	;USER mode is not initialized.
    mov	    pc,lr ;The LR register may be not valid for the mode changes.



;****************************************************
;*	The function for entering power down mode		*
;****************************************************
;void EnterPWDN(int CLKCON);
EnterPWDN
    mov	    r2,r0               ;r0=CLKCON
    ldr	    r0,=REFRESH		
    ldr	    r3,[r0]
    mov	    r1, r3
    orr	    r1, r1, #0x400000   ;self-refresh enable
    str	    r1, [r0]

    nop     ;Wait until self-refresh is issued. May not be needed.
    nop     ;If the other bus master holds the bus, ...
    nop	    ; mov r0, r0
    nop
    nop
    nop
    nop

;enter POWERDN mode
    ldr	    r0,=CLKCON
    str	    r2,[r0]

;wait until enter SL_IDLE,STOP mode and until wake-up
    ldr	    r0,=0x10
0   subs    r0,r0,#1
    bne	    %B0

;exit from DRAM/SDRAM self refresh mode.
    ldr	    r0,=REFRESH
    str	    r3,[r0]
    mov	    pc,lr



	LTORG

SMRDATA DATA
;*****************************************************************
;* Memory configuration has to be optimized for best performance *
;* The following parameter is not optimized.                     *
;*****************************************************************

;*** memory access cycle parameter strategy ***
; 1) Even FP-DRAM, EDO setting has more late fetch point by half-clock
; 2) The memory settings,here, are made the safe parameters even at 66Mhz.


    
	DCD 0x11111110	;Bank0=OM[1:0], Bank1~Bank7=16bit
   
	DCD ((B0_Tacs<<13)+(B0_Tcos<<11)+(B0_Tacc<<8)+(B0_Tcoh<<6)+(B0_Tah<<4)+(B0_Tacp<<2)+(B0_PMC))	;GCS0
	DCD ((B1_Tacs<<13)+(B1_Tcos<<11)+(B1_Tacc<<8)+(B1_Tcoh<<6)+(B1_Tah<<4)+(B1_Tacp<<2)+(B1_PMC))	;GCS1 
	DCD ((B2_Tacs<<13)+(B2_Tcos<<11)+(B2_Tacc<<8)+(B2_Tcoh<<6)+(B2_Tah<<4)+(B2_Tacp<<2)+(B2_PMC))	;GCS2
	DCD ((B3_Tacs<<13)+(B3_Tcos<<11)+(B3_Tacc<<8)+(B3_Tcoh<<6)+(B3_Tah<<4)+(B3_Tacp<<2)+(B3_PMC))	;GCS3
	DCD ((B4_Tacs<<13)+(B4_Tcos<<11)+(B4_Tacc<<8)+(B4_Tcoh<<6)+(B4_Tah<<4)+(B4_Tacp<<2)+(B4_PMC))	;GCS4
	DCD ((B5_Tacs<<13)+(B5_Tcos<<11)+(B5_Tacc<<8)+(B5_Tcoh<<6)+(B5_Tah<<4)+(B5_Tacp<<2)+(B5_PMC))	;GCS5
	
		DCD ((B6_MT<<15)+(B6_Trcd<<2)+(B6_SCAN))	;GCS6
		DCD ((B7_MT<<15)+(B7_Trcd<<2)+(B7_SCAN))	;GCS7
	
	DCD ((REFEN<<23)+(TREFMD<<22)+(Trp<<20)+(Trc<<18)+(Tchr<<16)+REFCNT)	;REFRESH RFEN=1, TREFMD=0, trp=3clk, trc=5clk, tchr=3clk,count=1019
	DCD 0x10			;SCLK power down mode, BANKSIZE 32M/32M
	DCD 0x20			;MRSR6 CL=2clk
	DCD 0x20			;MRSR7	

	AREA RamData, DATA, READWRITE

	^	(_ISR_STARTADDRESS-0x500)
				
UserStack	#	256	;cfffa00
SVCStack	#	256	;cfffb00
UndefStack	#	256	;cfffc00
AbortStack	#	256	;cfffd00
IRQStack	#	256	;cfffe00
FIQStack	#	0	;cffff00


		^	_ISR_STARTADDRESS
HandleReset	#	4
HandleUndef	#	4
HandleSWI	#	4
HandlePabort	#	4
HandleDabort	#	4
HandleReserved	#	4
HandleIRQ	#	4
HandleFIQ	#	4

;Don't use the label 'IntVectorTable',
;because armasm.exe cann't recognize this label correctly.
;the value is different with an address you think it may be.
;IntVectorTable
HandleADC	#	4
HandleRTC	#	4
HandleUTXD1	#	4
HandleUTXD0	#	4
HandleSIO	#	4
HandleIIC	#	4
HandleURXD1	#	4
HandleURXD0	#	4
HandleTIMER5	#	4
HandleTIMER4	#	4
HandleTIMER3	#	4
HandleTIMER2	#	4
HandleTIMER1	#	4
HandleTIMER0	#	4
HandleUERR01	#	4
HandleWDT	#	4
HandleBDMA1	#	4
HandleBDMA0	#	4
HandleZDMA1	#	4
HandleZDMA0	#	4
HandleTICK	#	4
HandleEINT4567	#	4
HandleEINT3	#	4
HandleEINT2	#	4
HandleEINT1	#	4
HandleEINT0	#	4   ;0xcffff84

		END

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区二区三区在线| 欧美日韩中文国产| 亚洲精品国产一区二区三区四区在线| 欧美性xxxxxx少妇| 国产白丝精品91爽爽久久| 丝袜亚洲精品中文字幕一区| 国产精品色一区二区三区| 日韩女同互慰一区二区| 欧美亚洲动漫制服丝袜| 国产乱子伦一区二区三区国色天香 | 国产精品久久久久影院色老大| 欧美精品色综合| 色呦呦一区二区三区| 国产精品99久久久久久似苏梦涵| 日韩精彩视频在线观看| 亚洲精品国产一区二区三区四区在线| 欧美精品一区二| 日韩一区二区精品葵司在线| 欧洲av在线精品| heyzo一本久久综合| 国产精品91xxx| 久久99久久久久久久久久久| 亚洲成a人v欧美综合天堂| 亚洲欧美日本在线| 中文字幕中文字幕在线一区| 久久精品夜色噜噜亚洲a∨| 欧美一区欧美二区| 欧美精品视频www在线观看| 91国偷自产一区二区开放时间| 波多野结衣亚洲| 成人黄色国产精品网站大全在线免费观看| 久久99精品久久久久久国产越南| 青青草国产精品97视觉盛宴| 日韩成人免费电影| 天天色天天操综合| 性做久久久久久久免费看| 亚洲国产另类精品专区| 亚洲第一福利一区| 亚洲国产精品一区二区久久恐怖片 | 日韩福利电影在线| 午夜精品福利一区二区三区蜜桃| 一区二区三区不卡在线观看 | 欧美大片拔萝卜| 欧美一区二区在线免费播放| 欧美老人xxxx18| 欧美精品久久一区| 91精品国产综合久久久久久漫画| 欧美精品电影在线播放| 欧美一区二区三区在线观看| 日韩视频永久免费| 久久综合色8888| 国产欧美综合在线观看第十页 | 偷拍一区二区三区| 日本不卡视频一二三区| 久久精品国产久精国产爱| 韩国精品主播一区二区在线观看| 国产精品一区二区久久精品爱涩| 成人午夜精品一区二区三区| a在线欧美一区| 欧美色综合天天久久综合精品| 欧美日韩国产免费| 精品国产免费久久| 国产精品色一区二区三区| 一区二区三区四区中文字幕| 日韩精品电影一区亚洲| 九色|91porny| 波多野结衣中文字幕一区二区三区| aa级大片欧美| 91精品国产一区二区人妖| 337p粉嫩大胆色噜噜噜噜亚洲 | 欧美一级专区免费大片| 国产亚洲人成网站| 尤物在线观看一区| 麻豆高清免费国产一区| 成人免费毛片高清视频| 欧美色综合久久| 久久精品夜色噜噜亚洲a∨| 亚洲欧美日韩电影| 美女一区二区久久| aaa欧美日韩| 日韩精品一区二区三区在线播放| 国产精品三级在线观看| 日韩精品乱码av一区二区| 国产aⅴ综合色| 欧美精选在线播放| 国产精品你懂的在线欣赏| 亚洲va欧美va天堂v国产综合| 狠狠v欧美v日韩v亚洲ⅴ| 99精品在线免费| 日韩一卡二卡三卡| 亚洲欧美日韩国产综合| 国产一区久久久| 欧美色图激情小说| 国产精品久久久爽爽爽麻豆色哟哟 | 欧美在线你懂的| 国产亚洲一二三区| 青青草成人在线观看| 91年精品国产| 久久嫩草精品久久久精品| 亚洲国产乱码最新视频| 北条麻妃国产九九精品视频| 欧美一区二区三区免费在线看 | 免费av成人在线| 91精彩视频在线| 欧美—级在线免费片| 日韩av在线播放中文字幕| 色呦呦网站一区| 日本一区二区电影| 激情欧美一区二区三区在线观看| 欧美日韩日本视频| 亚洲色图清纯唯美| 国产成人一区在线| 精品日产卡一卡二卡麻豆| 亚洲国产精品久久艾草纯爱| 91在线视频网址| 国产精品久久看| 风间由美一区二区三区在线观看| 日韩精品一区二区三区四区| 亚洲1区2区3区4区| 色爱区综合激月婷婷| 亚洲欧洲日韩在线| 成人av电影免费在线播放| 国产午夜亚洲精品理论片色戒| 久久精品999| 日韩欧美在线观看一区二区三区| 五月天亚洲婷婷| 欧美日韩电影一区| 午夜精品免费在线| 欧美久久高跟鞋激| 婷婷成人激情在线网| 欧美日韩视频在线一区二区| 亚洲一区二区三区三| 欧美亚洲禁片免费| 亚洲成人动漫av| 9191成人精品久久| 视频一区二区中文字幕| 91麻豆精品国产91| 日韩二区三区四区| 日韩免费成人网| 久久99最新地址| 国产亚洲精品中文字幕| 高清日韩电视剧大全免费| 国产精品人人做人人爽人人添| caoporm超碰国产精品| 亚洲人成亚洲人成在线观看图片| 色偷偷久久一区二区三区| 一区二区免费在线播放| 欧美中文字幕一区二区三区| 午夜久久久久久久久| 日韩欧美国产一二三区| 国产乱码精品一区二区三区忘忧草 | 最新日韩在线视频| 色噜噜狠狠色综合欧洲selulu| 一区二区三区**美女毛片| 欧美日本视频在线| 极品销魂美女一区二区三区| 国产午夜精品理论片a级大结局| 成人美女视频在线观看18| 亚洲欧美日韩综合aⅴ视频| 欧美在线你懂得| 久久福利资源站| 国产精品丝袜黑色高跟| 色视频成人在线观看免| 天天综合天天综合色| 久久久久国产精品麻豆ai换脸| 不卡电影一区二区三区| 亚洲午夜久久久久中文字幕久| 欧美一区在线视频| 粉嫩aⅴ一区二区三区四区五区| 亚洲精品网站在线观看| 欧美一区二区三区在线观看| 成人一级视频在线观看| 亚洲图片欧美综合| 国产亚洲精品福利| 欧美亚洲一区二区在线| 国产揄拍国内精品对白| 亚洲精品视频一区| 精品1区2区在线观看| 色综合久久66| 国产精品白丝jk白祙喷水网站| 亚洲一区二区精品3399| 久久久蜜臀国产一区二区| 在线观看日韩电影| 国产成人亚洲综合a∨婷婷| 亚洲一区在线观看免费观看电影高清 | 中文字幕一区二区三中文字幕| 欧美喷水一区二区| 成人国产亚洲欧美成人综合网| 午夜电影一区二区三区| 国产精品久久久久影视| 日韩一区二区三区在线视频| 99久久99精品久久久久久 | 日本欧美加勒比视频| 国产精品久久久久影视| 日韩久久精品一区| 日本国产一区二区| 高清不卡一区二区| 老司机免费视频一区二区| 亚洲一区二区三区自拍| 国产精品麻豆久久久|