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

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

?? hardware.asm

?? ARM設(shè)計(jì)實(shí)例
?? ASM
?? 第 1 頁 / 共 2 頁
字號:
// Function: The partial code of hardware setting of SACM_S480_Initial() 
//			or F_SACM_S480_Initial:
//////////////////////////////////////////////////////////////////
F_SP_SACM_S480_Init_:
        R1 = 0x0000						// 24MHz Fosc
        [P_SystemClock]=R1          	// Initial System Clock
        R1=0x0030                       // TimerA CKA=Fosc/2 CKB=1 Tout:off
        [P_TimerA_Ctrl]=R1				// Initial Timer A
        //R1 = 0xfd00                  	// 16K
        R1 = 0xfced						// 15.625K
        [P_TimerA_Data]=R1
        R1 = 0x00A8						// 
        [P_DAC_Ctrl] = R1				//
        
        R1 = 0xffff
        [P_INT_Clear] = R1          	// Clear interrupt occuiped events
        R1 = [R_InterruptStatus]		//
        R1 |= C_FIQ_TMA					// Enable Timer A FIQ
        //R1 |= C_IRQ4_1KHz				// Enable 1KHz IRQ4 for S480 decoder
        [R_InterruptStatus] = R1		//
        [P_INT_Ctrl] = R1				//
        
        RETF

//////////////////////////////////////////////////////////////////
// Function: The partial code of hardware setting of SACM_S240_Initial() 
//			or F_SACM_S240_Initial:
//////////////////////////////////////////////////////////////////
F_SP_SACM_S240_Init_:	
		R1=0x0020;	
		[P_SystemClock]=R1
		R1 = 0x00A8;					// 
		[P_DAC_Ctrl]= R1
		R1 = 0x0030;               	// TimerA CKA=Fosc/2 CKB=1 Tout:off
        [P_TimerA_Ctrl] = R1;
		R1 = 0xfe00;                    // 24K
    	[P_TimerA_Data] = R1;		
        R1 = 0xffff
        [P_INT_Clear] = R1          	// Clear interrupt occuiped events
        R1 = [R_InterruptStatus]		//
        R1 |= C_FIQ_TMA					// Enable Timer A FIQ
        [R_InterruptStatus] = R1		//
        [P_INT_Ctrl] = R1				//
        RETF

//////////////////////////////////////////////////////////////////
// Function: The partial code of hardware setting of SACM_MS01_Initial() 
//			or F_SACM_MS01_Initial:
//
//	Ex: F_SACM_MS01_Initial:
//			...
//			call F_SP_SACM_MS01_Init_
//			call F_SP_Play_Mode0/1/2/3	->0,1,2,3 depending on the para1
//			...
//			retf
//////////////////////////////////////////////////////////////////
F_SP_SACM_MS01_Init_:	
		R1 = 0x0000;                    // 24MHz, Fcpu=Fosc
        [P_SystemClock] = R1;        	// Initial System Clock
        R1 = 0x0030;                    // TimerA CKA=Fosc/2 CKB=1 Tout:off
        [P_TimerA_Ctrl] = R1			// Initial Timer A
        
        //R1 = 0x0003						// 8K
        R1 = 0x0000						// Fosc/2
        [P_TimerB_Ctrl] = R1;			// Initial Timer B -> 8192	
        
        //R1 = 0xFFFF        
        R1 = 0xFA00					// Any time for ADPCM channel 0,1
        [P_TimerB_Data] = R1			// 8K sample rate
        
		R1 = 0xffff
        [P_INT_Clear] = R1          	// Clear interrupt occuiped events
        RETF

//........................................
F_SP_PlayMode0_:						// with F_SP_SACM_MS01_Initial
		R1 = 0x0006
        [P_DAC_Ctrl] = R1
        R1 = 0xFE00
        [P_TimerA_Data] = R1 			//
        R1 = [R_InterruptStatus] 		//
        R1 |= C_FIQ_PWM+C_IRQ2_TMB+C_IRQ4_1KHz
        [R_InterruptStatus] = R1 		//
        [P_INT_Ctrl] = R1				//
        RETF

F_SP_PlayMode1_:						// with F_SP_SACM_MS01_Initial
		R1 = 0x00A8
        [P_DAC_Ctrl] = R1
        R1 = 0xFE00
        [P_TimerA_Data] = R1 			//
        R1 = [R_InterruptStatus] 		//
        R1 |= C_FIQ_TMA+C_IRQ2_TMB+C_IRQ4_1KHz
        [R_InterruptStatus] = R1 		//
        [P_INT_Ctrl] = R1				//
        RETF


F_SP_PlayMode2_:	 						// with F_SP_SACM_MS01_Initial
		R1 = 0x00A8
        [P_DAC_Ctrl] = R1
        R1 = 0xFD9A
        [P_TimerA_Data] = R1 				//
        R1 = [R_InterruptStatus] 			//
        R1 |= C_FIQ_TMA+C_IRQ2_TMB+C_IRQ4_1KHz
        [R_InterruptStatus] = R1 			//
        [P_INT_Ctrl] = R1					//
        RETF

      
F_SP_PlayMode3_:								// with F_SP_SACM_MS01_Initial
		R1 = 0x00A8
        [P_DAC_Ctrl] = R1
        R1 = 0xFD00
        [P_TimerA_Data] = R1 					//
        R1 = [R_InterruptStatus] 				//
        R1 |= C_FIQ_TMA+C_IRQ2_TMB+C_IRQ4_1KHz
	    [R_InterruptStatus] = R1 				//
        [P_INT_Ctrl] = R1						//
        RETF
        
///////////////////////////////////////////////////////////////////////////////
// Function: The partial code of hardware setting of SACM_MS01_Initial() 
//			or F_SACM_MS01_Initial:
//
//	Ex: F_SACM_DVR_Initial:
//			...
//			call F_SP_SACM_DVR_Init_
//			call F_SP_Play_Mode0/1/2/3	->0,1,2,3 depending on the para1
//			...
//			retf
//	Ex1:
//		F_SACM_DVR_Record: (or F_SACM_DVR_InitEncoder)
//			...
//			call F_SP_SACM_DVR_Rec_Init
//			...
//			retf
//	Ex2:
//		F_SACM_DVR_Play: (or F_SACM_DVR_InitDecoder)
//			...
//			call F_SP_SACM_DVR_Play_Init_
//			...
//			retf
///////////////////////////////////////////////////////////////////////////////
F_SP_SACM_DVR_Init_:
        r1 = 0x0000;                    // 24MHz, Fcpu=Fosc
        [P_SystemClock] = r1;           //  Frequency 20MHz
        r1 = 0x0030;                    // TimerA CKA=Fosc/2 CKB=1 Tout:off
        [P_TimerA_Ctrl] = r1;
        r1 = 0xfa00;                    // 8K @ 24.576MHz
        //r1 = 0xfb1d;                  // 8K @ 20MHz
        [P_TimerA_Data] = r1;
        r1 = 0x0035;                    // ADINI should be open (107)
        [P_ADC_Ctrl] = r1;
        r1 = 0x00A8;                    // Set the DA Ctrl
        [P_DAC_Ctrl] = r1;
        
        r1 = 0xffff;
        [P_INT_Clear] = r1;          	// Clear interrupt occuiped events
        
        R1 = [R_InterruptStatus]		//
        R1 |= C_FIQ_TMA					// Enable Timer A FIQ
        [R_InterruptStatus] = R1		//
        [P_INT_Ctrl] = R1				//
        
        RETF





F_SP_SACM_DVR_Rec_Init_:					// call by SACM_DVR_Record / SACM_DVR_InitEncoder
		r1 = 0x0035;  					//mic input
        //r1 = 0x0037					//line_in input
        [P_ADC_Ctrl] = r1;       		//enable ADC
        
        R1=0xfe00;                     	//24K @ 24.576MHz
        [P_TimerA_Data] = r1 
		RETF

F_SP_SACM_DVR_Play_Init_:
	    r1 = 0x0000						// call by SACM_DVR_Stop / SACM_DVR_Play
        [P_ADC_Ctrl] = r1;       		// Disable ADC
        
        r1 = 0xfd00;                	// 16K @ 24.576MHz
        [P_TimerA_Data] = r1;
        RETF




/////////////////////////////////////////////////////////////////////////////// 
// Function: Extra Functions provided by Sunplus
//	Type:	
//		1. DAC Ramp up/down
//		2. IO config/import/export
//		3. Get resource data
//
//
///////////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////
// Function: Ramp Up/Down to avoid speaker "pow" noise
// Destory: R1,R2
////////////////////////////////////////////////////////
_SP_RampUpDAC1:	.PROC
F_SP_RampUpDAC1:
		push r1,r2 to [sp] 
        r1=[P_DAC1] 
        r1 &= ~0x003f 
        cmp     r1,0x8000
        jb     	L_RU_NormalUp
        je      L_RU_End
                
L_RU_DownLoop:
        call    F_Delay         
        r2 = 0x0001 
        [P_Watchdog_Clear] = r2 
        r1 -= 0x40 
        [P_DAC1] = r1 
        cmp     r1,0x8000 
        jne     L_RU_DownLoop   
L_RD_DownEnd:
        jmp     L_RU_End 

L_RU_NormalUp:
L_RU_Loop:
        call    F_Delay 
        r2 = 0x0001 
        [P_Watchdog_Clear] = r2 
        r1 += 0x40 
        [P_DAC1] = r1 
        cmp     r1, 0x8000 
        jne     L_RU_Loop 
L_RU_End:
		pop     r1,r2 from [sp] 
  		retf 
    	.ENDP
    
//............................................................
_SP_RampDnDAC1:	.PROC
F_SP_RampDnDAC1:
		push r1,r2 to [sp] 
  		//int off 
    	r1 = [P_DAC1] 
     	r1 &= ~0x003F 
      	jz      L_RD_End 
L_RD_Loop:                
        call    F_Delay         
        r2 = 0x0001 
        [P_Watchdog_Clear] = r2 
        r1 -= 0x40 
        [P_DAC1] = r1   
        jnz     L_RD_Loop 
L_RD_End:       
		//int	fiq,irq
        pop     r1,r2 from [sp] 
        retf 
		.ENDP

//..............................................................
_SP_RampUpDAC2:	.PROC
F_SP_RampUpDAC2:
		push r1,r2 to [sp] 
  		r1=[P_DAC2] 
    	r1 &= ~0x003f 
     	cmp     r1,0x8000
      	jb     	L_RU_NormalUp_   
       	je      L_RU_End 
                
L_RU_DownLoop_:
        call    F_Delay         
        r2 = 0x0001 
        [P_Watchdog_Clear] = r2 
        r1 -= 0x40 
        [P_DAC2] = r1 
        cmp     r1,0x8000 
        jne     L_RU_DownLoop_   
L_RD_DownEnd_:
        jmp     L_RU_End_ 

L_RU_NormalUp_:
L_RU_Loop_:
		call    F_Delay 
  		r2 = 0x0001 
    	[P_Watchdog_Clear] = r2 
        r1 += 0x40 
        [P_DAC2] = r1 
        cmp     r1, 0x8000 
        jne     L_RU_Loop_ 
L_RU_End_:
   		pop     r1,r2 from [sp] 
     	retf 
      	.ENDP
//.............................................................
_SP_RampDnDAC2:	.PROC
F_SP_RampDnDAC2:
		//int off 
		push r1,r2 to [sp] 
                
        r1 = [P_DAC2] 
        r1 &= ~0x003F 
        jz      L_RD_End_ 
L_RD_Loop_:                
        call    F_Delay         
        r2 = 0x0001 
        [P_Watchdog_Clear] = r2 
        r1 -= 0x40 
        [P_DAC2] = r1   
        jnz     L_RD_Loop_ 
L_RD_End_:       
        pop     r1,r2 from [sp] 
        retf 
		.ENDP

//..................................................................				
F_Delay:
        push r1 to [sp] 
        r1 = C_RampDelayTime			// Ramp Up/Dn delay per step
L_D_Loop:
        r1 -= 1 
        jnz     L_D_Loop  
        pop     r1 from [sp] 
        RETF	 



////////////////////////////////////////////////////////////////
// Function: I/O Port A configuration
// 	void SP_Inti_IOA(int Dir, int Data, int Attrib)
////////////////////////////////////////////////////////////////
_SP_Init_IOA: .PROC
		PUSH BP TO [SP] 
        BP = SP + 1 
		PUSH R1 TO [SP] 
		R1 = [BP+3] 						// Port direction
		[P_IOA_Dir] = R1 
		R1 = [BP+4] 
		[P_IOA_Data] = R1 
		R1 = [BP+5] 
		[P_IOA_Attrib] = R1 
		
		POP R1 FROM [SP] 
        POP BP FROM [SP] 
        RETF 
		.ENDP

////////////////////////////////////////////////////////////////// 
// Function: I/O Port B configuration
//  void SP_Inti_IOB(int Dir, int Data, int Attrib)
//////////////////////////////////////////////////////////////////    
_SP_Init_IOB: .PROC
		PUSH BP TO [SP] 
        BP = SP + 1 
		PUSH R1 TO [SP] 
		R1 = [BP+3] 						// Port direction
		[P_IOB_Dir] = R1 
		R1 = [BP+4] 
		[P_IOB_Data] = R1 
		R1 = [BP+5] 
		[P_IOB_Attrib] = R1 
		
		POP R1 FROM [SP] 
        POP BP FROM [SP] 
        RETF 
		.ENDP

////////////////////////////////////////////////////////////////// 
// Function: Get data from port
// 	int SP_Import(unsigned int Port)
//////////////////////////////////////////////////////////////////  
_SP_Import: .PROC
        PUSH BP TO [SP] 
        BP = SP + 1 
        
		R1 = [BP+3]  						// Port Number
		R1 = [R1]  
				
        POP BP FROM [SP] 
        RETF 
		.ENDP

_SP_Export: .PROC
        PUSH BP,BP TO [SP] 
        BP = SP + 1 
		PUSH R1,R2 TO [SP] 
		R1 = [BP+3]  						// Port Number
		R2 = [BP+4]  						// Value
		[R1] = R2  
		POP R1,R2 FROM [SP] 
        POP BP,BP FROM [SP] 
        RETF         
 		.ENDP


////////////////////////////////////////////////////////////////// 
// Function: Get data from resource(ROM area)
// 	int SP_GetResource(int Addr, int Page)
//////////////////////////////////////////////////////////////////  
_SP_GetResource:	.PROC
		push bp to [sp] 
		bp = sp + 1 
		
		r1 = [bp+3] 					// Address
		r2 = [bp+4] 					// Page
		
		r2 = r2 lsl 4 					// Prepare Page for SR
		r2 = r2 lsl 4 
		r2 = r2 lsl 2 
		
		sr &= 0x03f 					// Change Page
        r2 |=sr 						//
        sr = r2 						//
  
  		r1 = D:[r1] 					// Get data
       
		pop	 bp from [sp] 
		retf 
		.ENDP 
//........................................
F_SP_GetResource:
		r2 = r2 lsl 4 					// Prepare Page for SR
		r2 = r2 lsl 4 
		r2 = r2 lsl 2 
		
		sr &= 0x03f 					// Change Page
        r2 |=sr 						//
        sr = r2 						//
  
  		r1 = D:[r1] 					// Get data
	  	retf

//////////////////////////////////////////////////////////////////
// Functions: Reserve old defintion
// Note: 	1. Some user who use old library may use the old name
//			2. Have to be put at the end of this file
//////////////////////////////////////////////////////////////////
.PUBLIC	F_RampUpDAC1 
.PUBLIC	F_RampDnDAC1 
.PUBLIC	F_RampUpDAC2 
.PUBLIC	F_RampDnDAC2 
.PUBLIC	_STD_RampUpDAC1 
.PUBLIC	_STD_RampDnDAC1 
.PUBLIC	_STD_RampUpDAC2 
.PUBLIC	_STD_RampDnDAC2 

.DEFINE F_RampUpDAC1 F_SP_RampUpDAC1
.DEFINE F_RampDnDAC1 F_SP_RampDnDAC1
.DEFINE F_RampUpDAC2 F_SP_RampUpDAC2
.DEFINE F_RampDnDAC2 F_SP_RampDnDAC2
.DEFINE _STD_RampUpDAC1 _SP_RampUpDAC1
.DEFINE _STD_RampDnDAC1 _SP_RampDnDAC1
.DEFINE _STD_RampUpDAC2 _SP_RampUpDAC2
.DEFINE _STD_RampDnDAC2 _SP_RampDnDAC2


///////////////////////////////////////////////////////////////////
                
//========================================================================================        
// End of hardware.asm
//========================================================================================



        
        
        

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
理论片日本一区| 欧美精品一区二区精品网| 色婷婷狠狠综合| 中文字幕色av一区二区三区| 国产精选一区二区三区| 欧美精品一区二区三区在线播放| 亚洲大片一区二区三区| 欧美视频一区二区三区四区 | 欧洲国产伦久久久久久久| 国产清纯在线一区二区www| 精彩视频一区二区三区| 久久综合成人精品亚洲另类欧美 | 国内偷窥港台综合视频在线播放| 欧美日韩另类国产亚洲欧美一级| 丝袜诱惑亚洲看片| 精品三级在线看| 国产乱码精品一区二区三区av | 中文一区二区完整视频在线观看| 国产毛片精品一区| 中文字幕一区视频| 色狠狠色狠狠综合| 精品一区二区三区免费视频| 精品国产乱子伦一区| 国产成人精品三级麻豆| 亚洲国产一区二区视频| 久久久午夜精品理论片中文字幕| 床上的激情91.| 青青草一区二区三区| 国产精品久久久久久福利一牛影视| 色妞www精品视频| 国产美女在线精品| 亚洲成人先锋电影| 国产精品麻豆99久久久久久| 欧美一区二区三区免费观看视频 | 首页国产欧美日韩丝袜| 精品国产一二三| 欧美伊人久久久久久久久影院 | 亚洲激情自拍视频| 久久精品一区蜜桃臀影院| 欧美狂野另类xxxxoooo| 91老师国产黑色丝袜在线| 久久精品噜噜噜成人av农村| 亚洲一区二区在线免费看| 国产精品无遮挡| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 欧美亚洲动漫精品| 97se亚洲国产综合在线| 国产一本一道久久香蕉| 国产精品一区二区x88av| 久久国产免费看| 日韩女优毛片在线| 欧美色中文字幕| 色猫猫国产区一区二在线视频| 黄色成人免费在线| 黄色日韩网站视频| 国产精品一品视频| 成人福利视频在线看| 成人免费av资源| 成人黄色在线视频| 91老司机福利 在线| 亚洲综合色噜噜狠狠| 欧美性受xxxx| 91视频在线观看免费| 欧美在线一二三四区| 色成人在线视频| 欧美色精品在线视频| 欧美嫩在线观看| 欧美精品一区视频| 国产精品毛片久久久久久久| 亚洲视频一区在线| 五月天久久比比资源色| 激情欧美一区二区三区在线观看| 国产二区国产一区在线观看| 99视频在线精品| 欧美一区二区三区色| 国产精品乱人伦中文| 日韩电影免费在线观看网站| 亚洲国产中文字幕在线视频综合| 免费视频一区二区| 97精品视频在线观看自产线路二| 在线观看视频一区| 欧美国产禁国产网站cc| 奇米精品一区二区三区在线观看一 | 日韩视频免费直播| 国产精品久久99| 国产在线播放一区| 91精品国产综合久久精品麻豆| 国产三级精品在线| 久久99国产精品久久99| 欧美日本一道本在线视频| 国产精品久久久久久久久免费相片 | 欧美最猛黑人xxxxx猛交| 中文字幕欧美日本乱码一线二线| 日本在线播放一区二区三区| 欧美色图12p| 亚洲一区二区在线观看视频| 99久久国产免费看| 欧美国产日产图区| 成人黄色小视频在线观看| 久久久午夜精品| 成人自拍视频在线观看| 国产亚洲成av人在线观看导航| 久久超级碰视频| 精品国产伦一区二区三区观看体验| 日本美女一区二区三区| 日韩亚洲欧美在线| 美国一区二区三区在线播放| 精品国产一区久久| 国产成人av电影免费在线观看| 国产欧美精品一区aⅴ影院 | 视频一区视频二区在线观看| 欧美日韩免费观看一区二区三区 | 国产日韩欧美一区二区三区综合| 国产一区福利在线| 亚洲图片另类小说| 一本色道综合亚洲| 日本美女一区二区三区| 国产三级精品三级在线专区| 色噜噜狠狠成人中文综合| 免费在线看成人av| 国产精品女上位| 91精品在线免费观看| 国产一区二区久久| 亚洲欧美日韩综合aⅴ视频| 欧美视频完全免费看| 国产一级精品在线| 日韩黄色免费网站| 99精品一区二区三区| 日韩精品1区2区3区| 国产精品久久久久久久久搜平片| 欧美日韩一区国产| 成人app网站| 国产丶欧美丶日本不卡视频| 亚洲在线视频网站| 久久久久久电影| 91精品在线一区二区| 91亚洲大成网污www| 国产丶欧美丶日本不卡视频| 青青草97国产精品免费观看无弹窗版 | 欧美性色综合网| 国产乱一区二区| 男女男精品网站| 日韩激情一二三区| 一区二区三区久久| 国产精品萝li| 中文字幕一区二区三区在线播放| 日韩久久久久久| 日韩欧美国产精品| 欧美一级一级性生活免费录像| 欧美综合视频在线观看| 色拍拍在线精品视频8848| 91蜜桃传媒精品久久久一区二区| 亚洲成人在线免费| 亚洲国产日韩一级| 蜜乳av一区二区| 国产做a爰片久久毛片 | 亚洲日本在线a| 亚洲一区二区五区| 三级影片在线观看欧美日韩一区二区| 亚洲综合无码一区二区| 免费的成人av| 成人午夜电影网站| 91电影在线观看| 日韩精品中文字幕在线一区| 精品三级av在线| 亚洲婷婷综合久久一本伊一区| 亚洲美女区一区| 免费高清在线视频一区·| 成人av在线播放网站| 欧美日韩一区中文字幕| 欧美电影免费观看高清完整版在 | 91精品国产综合久久精品app| 精品日产卡一卡二卡麻豆| ㊣最新国产の精品bt伙计久久| 亚洲国产日韩a在线播放性色| 精品无码三级在线观看视频 | 久久99热狠狠色一区二区| gogo大胆日本视频一区| 欧美一级二级三级蜜桃| 成人免费在线观看入口| 极品少妇xxxx偷拍精品少妇| 99精品欧美一区二区三区综合在线| 91.com视频| 亚洲美女屁股眼交| 成人av在线资源| 在线观看91av| 亚洲一区二区视频| eeuss鲁片一区二区三区在线看| 欧美va亚洲va香蕉在线| 性感美女极品91精品| 一本色道久久综合亚洲91| 欧美国产精品一区| 国产九色sp调教91| 精品国产91亚洲一区二区三区婷婷| 一区二区三区四区五区视频在线观看| 国产激情一区二区三区四区| 91精品国产一区二区| 日本 国产 欧美色综合| 日韩女优视频免费观看| 久久99精品国产91久久来源|