⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hardware.lst

📁 基于凌阳单片机的简单的工业顺序控制
💻 LST
📖 第 1 页 / 共 4 页
字号:
0000ACAF 09 23 40 00        	        r1 -= 0x40 
0000ACB1 19 D3 17 70        	        [P_DAC1] = r1 
0000ACB3 09 43 00 80        	        cmp     r1,0x8000 
0000ACB5 4C 4E              	        jne     L_RU_DownLoop   
                            	L_RD_DownEnd:
0000ACB6 0C EE              	        jmp     L_RU_End 
                            	
                            	L_RU_NormalUp:
                            	L_RU_Loop:
0000ACB7 40 F0 0D AD        	        call    F_Delay 
0000ACB9 41 94              	        r2 = 0x0001 
0000ACBA 1A D5 12 70        	        [P_Watchdog_Clear] = r2 
0000ACBC 09 03 40 00        	        r1 += 0x40 
0000ACBE 19 D3 17 70        	        [P_DAC1] = r1 
0000ACC0 09 43 00 80        	        cmp     r1, 0x8000 
0000ACC2 4C 4E              	        jne     L_RU_Loop 
                            	L_RU_End:
0000ACC3 90 90              			pop     r1,r2 from [sp] 
0000ACC4 90 9A              	  		retf 
                            	    	.ENDP
                            	    
                            	//............................................................
                            	_SP_RampDnDAC1:	.PROC
                            	F_SP_RampDnDAC1:
0000ACC5 90 D4              			push r1,r2 to [sp] 
                            	  		//int off 
0000ACC6 11 93 17 70        	    	r1 = [P_DAC1] 
0000ACC8 09 B3 C0 FF        	     	r1 &= ~0x003F 
0000ACCA 0A 5E              	      	jz      L_RD_End 
                            	L_RD_Loop:                
0000ACCB 40 F0 0D AD        	        call    F_Delay         
0000ACCD 41 94              	        r2 = 0x0001 
0000ACCE 1A D5 12 70        	        [P_Watchdog_Clear] = r2 
0000ACD0 09 23 40 00        	        r1 -= 0x40 
0000ACD2 19 D3 17 70        	        [P_DAC1] = r1   
0000ACD4 4A 4E              	        jnz     L_RD_Loop 
                            	L_RD_End:       
                            			//int	fiq,irq
0000ACD5 90 90              	        pop     r1,r2 from [sp] 
0000ACD6 90 9A              	        retf 
                            			.ENDP
                            	
                            	//..............................................................
                            	_SP_RampUpDAC2:	.PROC
                            	F_SP_RampUpDAC2:
0000ACD7 90 D4              			push r1,r2 to [sp] 
0000ACD8 11 93 16 70        	  		r1=[P_DAC2] 
0000ACDA 09 B3 C0 FF        	    	r1 &= ~0x003f 
0000ACDC 09 43 00 80        	     	cmp     r1,0x8000
0000ACDE 0E 0E              	      	jb     	L_RU_NormalUp_   
0000ACDF 5D 5E              	       	je      L_RU_End 
                            	                
                            	L_RU_DownLoop_:
0000ACE0 40 F0 0D AD        	        call    F_Delay         
0000ACE2 41 94              	        r2 = 0x0001 
0000ACE3 1A D5 12 70        	        [P_Watchdog_Clear] = r2 
0000ACE5 09 23 40 00        	        r1 -= 0x40 
0000ACE7 19 D3 16 70        	        [P_DAC2] = r1 
0000ACE9 09 43 00 80        	        cmp     r1,0x8000 
0000ACEB 4C 4E              	        jne     L_RU_DownLoop_   
                            	L_RD_DownEnd_:
0000ACEC 0C EE              	        jmp     L_RU_End_ 
                            	
                            	L_RU_NormalUp_:
                            	L_RU_Loop_:
0000ACED 40 F0 0D AD        			call    F_Delay 
0000ACEF 41 94              	  		r2 = 0x0001 
0000ACF0 1A D5 12 70        	    	[P_Watchdog_Clear] = r2 
0000ACF2 09 03 40 00        	        r1 += 0x40 
0000ACF4 19 D3 16 70        	        [P_DAC2] = r1 
0000ACF6 09 43 00 80        	        cmp     r1, 0x8000 
0000ACF8 4C 4E              	        jne     L_RU_Loop_ 
                            	L_RU_End_:
0000ACF9 90 90              	   		pop     r1,r2 from [sp] 
0000ACFA 90 9A              	     	retf 
                            	      	.ENDP
                            	//.............................................................
                            	_SP_RampDnDAC2:	.PROC
                            	F_SP_RampDnDAC2:
                            			//int off 
0000ACFB 90 D4              			push r1,r2 to [sp] 
                            	                
0000ACFC 11 93 16 70        	        r1 = [P_DAC2] 
0000ACFE 09 B3 C0 FF        	        r1 &= ~0x003F 
0000AD00 0A 5E              	        jz      L_RD_End_ 
                            	L_RD_Loop_:                
0000AD01 40 F0 0D AD        	        call    F_Delay         
0000AD03 41 94              	        r2 = 0x0001 
0000AD04 1A D5 12 70        	        [P_Watchdog_Clear] = r2 
0000AD06 09 23 40 00        	        r1 -= 0x40 
0000AD08 19 D3 16 70        	        [P_DAC2] = r1   
0000AD0A 4A 4E              	        jnz     L_RD_Loop_ 
                            	L_RD_End_:       
0000AD0B 90 90              	        pop     r1,r2 from [sp] 
0000AD0C 90 9A              	        retf 
                            			.ENDP
                            	
                            	//..................................................................				
                            	F_Delay:
0000AD0D 88 D2              	        push r1 to [sp] 
0000AD0E 60 92              	        r1 = C_RampDelayTime			// Ramp Up/Dn delay per step
                            	L_D_Loop:
0000AD0F 41 22              	        r1 -= 1 
0000AD10 42 4E              	        jnz     L_D_Loop  
0000AD11 88 90              	        pop     r1 from [sp] 
0000AD12 90 9A              	        RETF	 
                            	
                            	
                            	
                            	////////////////////////////////////////////////////////////////
                            	// Function: I/O Port A configuration
                            	// 	void SP_Inti_IOA(int Dir, int Data, int Attrib)
                            	////////////////////////////////////////////////////////////////
                            	_SP_Init_IOA: .PROC
0000AD13 88 DA              			PUSH bp TO [sp] 
0000AD14 08 0B 01 00        	        bp = sp + 1 
0000AD16 88 D2              			PUSH r1 TO [sp] 
0000AD17 03 92              			r1 = [bp+3] 						// Port direction
0000AD18 19 D3 02 70        			[P_IOA_Dir] = r1 
0000AD1A 04 92              			r1 = [bp+4] 
0000AD1B 19 D3 00 70        			[P_IOA_Data] = r1 
0000AD1D 05 92              			r1 = [bp+5] 
0000AD1E 19 D3 03 70        			[P_IOA_Attrib] = r1 
                            			
0000AD20 88 90              			POP r1 FROM [sp] 
0000AD21 88 98              	        POP bp FROM [sp] 
0000AD22 90 9A              	        RETF 
                            			.ENDP
                            	
                            	////////////////////////////////////////////////////////////////// 
                            	// Function: I/O Port B configuration
                            	//  void SP_Inti_IOB(int Dir, int Data, int Attrib)
                            	//////////////////////////////////////////////////////////////////    
                            	_SP_Init_IOB: .PROC
0000AD23 88 DA              			PUSH bp TO [sp] 
0000AD24 08 0B 01 00        	        bp = sp + 1 
0000AD26 88 D2              			PUSH r1 TO [sp] 
0000AD27 03 92              			r1 = [bp+3] 						// Port direction
0000AD28 19 D3 07 70        			[P_IOB_Dir] = r1 
0000AD2A 04 92              			r1 = [bp+4] 
0000AD2B 19 D3 05 70        			[P_IOB_Data] = r1 
0000AD2D 05 92              			r1 = [bp+5] 
0000AD2E 19 D3 08 70        			[P_IOB_Attrib] = r1 
                            			
0000AD30 88 90              			POP r1 FROM [sp] 
0000AD31 88 98              	        POP bp FROM [sp] 
0000AD32 90 9A              	        RETF 
                            			.ENDP
                            	
                            	////////////////////////////////////////////////////////////////// 
                            	// Function: Get data from port
                            	// 	int SP_Import(unsigned int Port)
                            	//////////////////////////////////////////////////////////////////  
                            	_SP_Import: .PROC
0000AD33 88 DA              	        PUSH bp TO [sp] 
0000AD34 08 0B 01 00        	        bp = sp + 1 
                            	        
0000AD36 03 92              			r1 = [bp+3]  						// Port Number
0000AD37 C1 92              			r1 = [r1]  
                            					
0000AD38 88 98              	        POP bp FROM [sp] 
0000AD39 90 9A              	        RETF 
                            			.ENDP
                            	
                            	_SP_Export: .PROC
0000AD3A 88 DA              	        PUSH bp,bp TO [sp] 
0000AD3B 41 00              	        sp = sp + 1 
0000AD3C 90 D4              			PUSH r1,r2 TO [sp] 
0000AD3D 03 92              			r1 = [bp+3]  						// Port Number
0000AD3E 04 94              			r2 = [bp+4]  						// Value
0000AD3F C1 D4              			[r1] = r2  
0000AD40 90 90              			POP r1,r2 FROM [sp] 
0000AD41 88 98              	        POP bp,bp FROM [sp] 
0000AD42 90 9A              	        RETF         
                            	 		.ENDP
                            	
                            	
                            	////////////////////////////////////////////////////////////////// 
                            	// Function: Get data from resource(ROM area)
                            	// 	int SP_GetResource(int Addr, int Page)
                            	//////////////////////////////////////////////////////////////////  
                            	_SP_GetResource:	.PROC
0000AD43 88 DA              			push bp to [sp] 
0000AD44 08 0B 01 00        			bp = sp + 1 
                            			
0000AD46 03 92              			r1 = [bp+3] 					// Address
0000AD47 04 94              			r2 = [bp+4] 					// Page
                            			
0000AD48 5A 95              			r2 = r2 lsl 4 					// Prepare Page for SR
0000AD49 5A 95              			r2 = r2 lsl 4 
0000AD4A 4A 95              			r2 = r2 lsl 2 
                            			
0000AD4B 7F BC              			sr &= 0x03f 					// Change Page
0000AD4C 06 A5              	        r2 |=sr 						//
0000AD4D 02 9D              	        sr = r2 						//
                            	  
0000AD4E E1 92              	  		r1 = D:[r1] 					// Get data
                            	       
0000AD4F 88 98              			pop	 bp from [sp] 
0000AD50 90 9A              			retf 
                            			.ENDP 
                            	//........................................
                            	F_SP_GetResource:
0000AD51 5A 95              			r2 = r2 lsl 4 					// Prepare Page for SR
0000AD52 5A 95              			r2 = r2 lsl 4 
0000AD53 4A 95              			r2 = r2 lsl 2 
                            			
0000AD54 7F BC              			sr &= 0x03f 					// Change Page
0000AD55 06 A5              	        r2 |=sr 						//
0000AD56 02 9D              	        sr = r2 						//
                            	  
0000AD57 E1 92              	  		r1 = D:[r1] 					// Get data
0000AD58 90 9A              		  	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
                            	//========================================================================================
                            	
                            	
                            	
                            	        
                            	        
                            	        
0 error(s), 0 warning(s).

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -