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

📄 hardware.lst

📁 波形发生器
💻 LST
📖 第 1 页 / 共 3 页
字号:
00009FE2 09 23 40 00        	                r1 -= 0x40;
00009FE4 19 D3 17 70        	                [P_DAC1] = r1;  
00009FE6 4A 4E              	                jnz     L_RD_Loop;
                            	L_RD_End:       
                            	                
00009FE7 90 90              	                pop     r1,r2 from [sp];
00009FE8 90 9A              	                retf;
                            					.ENDP
                            	
                            	///////////////////////////////////////
                            	_SP_RampUpDAC2:	.PROC
                            	F_SP_RampUpDAC2:
00009FE9 90 D4              	                push r1,r2 to [sp];
00009FEA 11 93 16 70        	                r1=[P_DAC2];
00009FEC 09 B3 C0 FF        	                r1 &= ~0x003f;
00009FEE 09 43 00 80        	                cmp     r1,0x8000
00009FF0 0E 0E              	                jb     	L_RU_NormalUp_;  
00009FF1 5D 5E              	                je      L_RU_End;
                            	                
                            	L_RU_DownLoop_:
00009FF2 40 F0 1F A0        	                call    F_Delay;        
00009FF4 41 94              	                r2 = 0x0001;
00009FF5 1A D5 12 70        	                [P_Watchdog_Clear] = r2;
00009FF7 09 23 40 00        	                r1 -= 0x40;
00009FF9 19 D3 16 70        	                [P_DAC2] = r1;
00009FFB 09 43 00 80        	                cmp     r1,0x8000;
00009FFD 4C 4E              	                jne     L_RU_DownLoop_;  
                            	L_RD_DownEnd_:
00009FFE 0C EE              	                jmp     L_RU_End_;
                            	
                            	L_RU_NormalUp_:
                            	L_RU_Loop_:
00009FFF 40 F0 1F A0        	                call    F_Delay;
0000A001 41 94              	                r2 = 0x0001;
0000A002 1A D5 12 70        	                [P_Watchdog_Clear] = r2;
0000A004 09 03 40 00        	                r1 += 0x40;
0000A006 19 D3 16 70        	                [P_DAC2] = r1;
0000A008 09 43 00 80        	                cmp     r1, 0x8000;
0000A00A 4C 4E              	                jne     L_RU_Loop_;
                            	                
                            	
                            	L_RU_End_:
0000A00B 90 90              	                pop     r1,r2 from [sp];
0000A00C 90 9A              	                retf;
                            	                .ENDP
                            	/////////////////////////////////////// 
                            	_SP_RampDnDAC2:	.PROC
                            	F_SP_RampDnDAC2:
                            					//int off;
0000A00D 90 D4              					push r1,r2 to [sp];
                            	                
0000A00E 11 93 16 70        	                r1 = [P_DAC2];
0000A010 09 B3 C0 FF        	                r1 &= ~0x003F;
0000A012 0A 5E              	                jz      L_RD_End_;
                            	L_RD_Loop_:                
0000A013 40 F0 1F A0        	                call    F_Delay;        
0000A015 41 94              	                r2 = 0x0001;
0000A016 1A D5 12 70        	                [P_Watchdog_Clear] = r2;
0000A018 09 23 40 00        	                r1 -= 0x40;
0000A01A 19 D3 16 70        	                [P_DAC2] = r1;  
0000A01C 4A 4E              	                jnz     L_RD_Loop_;
                            	L_RD_End_:       
                            	                
0000A01D 90 90              	                pop     r1,r2 from [sp];
0000A01E 90 9A              	                retf;
                            					.ENDP
                            	////////////////////////////////////////
                            	
                            	F_Delay:
0000A01F 88 D2              	                push r1 to [sp];
0000A020 48 92              	                r1 = 8;
                            	L_D_Loop:
0000A021 41 22              	                r1 -= 1;
0000A022 42 4E              	                jnz     L_D_Loop; 
0000A023 88 90              	                pop     r1 from [sp];
0000A024 90 9A              	                retf;	 
                            	                
                            	                
                            	///////////////////////////////////////////
                            	// Function: Initial Queue
                            	// Destory: R1,R2
                            	///////////////////////////////////////////	
                            	
                            	F_SP_InitQueue:
0000A025 09 93 BD 01        			R1 = R_Queue;
0000A027 40 94              			R2 = 0;
                            	L_ClearQueueLoop:		
0000A028 D1 D4              			[R1++] = R2;
0000A029 09 43 EF 01        			cmp	R1, R_Queue+C_QueueSize;
0000A02B 44 4E              			jne	L_ClearQueueLoop;
                            				
0000A02C 40 92              			R1 = 0;
0000A02D 19 D3 EF 01        			[R_ReadIndex] = R1;
0000A02F 19 D3 F0 01        			[R_WriteIndex] = R1;
                            					
0000A031 90 9A              			retf;
                            			
                            	///////////////////////////////////////////
                            	// Function: Get a data form Queue
                            	// Output:  R1: Data
                            	//			R2: return value
                            	// Destory: R1,R2
                            	///////////////////////////////////////////		
                            	F_SP_ReadQueue:
                            	
0000A032 12 95 EF 01        			R2 = [R_ReadIndex];
0000A034 12 45 F0 01        			cmp R2,[R_WriteIndex];
0000A036 0C 5E              			je	L_RQ_QueueEmpty;
                            	
0000A037 0A 05 BD 01        			R2 += R_Queue;				// get queue data address
0000A039 C2 92              			R1 = [R2];
                            			
0000A03A 12 95 EF 01        			R2 = [R_ReadIndex];
0000A03C 41 04              			R2 += 1;
0000A03D 72 44              			cmp	R2, C_QueueSize;
0000A03E 01 4E              			jne	L_RQ_NotQueueBottom;
0000A03F 40 94              			R2 = 0;
                            	L_RQ_NotQueueBottom:	
0000A040 1A D5 EF 01        			[R_ReadIndex] = R2;			
                            			//r2 = 0x0000;						// get queue data
0000A042 90 9A              			retf;
                            	
                            	L_RQ_QueueEmpty:
                            			//r2 = 0x8000;						// queue empty
0000A043 90 9A              			retf;
                            	///////////////////////////////////////////
                            	// Function: Put a data to Queue
                            	// R1: Input
                            	// Destory: R1,R2,R3
                            	///////////////////////////////////////////	
                            				
                            	F_SP_WriteQueue:
0000A044 12 95 F0 01        			R2 = [R_WriteIndex];			// put data to queue
0000A046 0A 05 BD 01        			R2 += R_Queue;
0000A048 C2 D2              			[R2] = R1;
                            	
0000A049 12 95 F0 01        			R2 = [R_WriteIndex];
0000A04B 41 04              			R2 += 1;
0000A04C 72 44              			cmp	R2, C_QueueSize;
0000A04D 01 4E              			jne	L_WQ_NotQueueBottom;
0000A04E 40 94              			R2 = 0;
                            	L_WQ_NotQueueBottom:
0000A04F 1A D5 F0 01        			[R_WriteIndex] = R2;
0000A051 90 9A              			retf;
                            			
                            	//..........................................
                            	F_SP_TestQueue:
                            			//... Test Queue Empty ...
0000A052 11 93 EF 01        			R1 = [R_ReadIndex];
0000A054 11 43 F0 01        			cmp R1,[R_WriteIndex];
0000A056 11 5E              			je	L_TQ_QueueEmpty;
                            	
                            			//... Test Queue Full ...
0000A057 11 93 EF 01        			R1 = [R_ReadIndex];				// For N Queue Full: 1. W=R-1 2.R=0/W=N-1
0000A059 04 4E              			jnz	L_TQ_JudgeCond2;
0000A05A 11 93 F0 01        			R1 = [R_WriteIndex];
0000A05C 71 42              			cmp	R1, C_QueueSize-1;			// Cond1
0000A05D 08 5E              			je	L_TQ_QueueFull;			
                            	L_TQ_JudgeCond2:		
0000A05E 11 93 EF 01        			R1 = [R_ReadIndex];
0000A060 41 22              			R1 -=1;
0000A061 11 43 F0 01        			cmp R1,[R_WriteIndex];
0000A063 02 5E              			je	L_TQ_QueueFull;	
                            	
0000A064 40 92              			r1 = 0;							// not Full, not empty
0000A065 90 9A              			retf;
                            	L_TQ_QueueFull:
0000A066 41 92              			r1 = 1;							// full
0000A067 90 9A              			retf;
                            	L_TQ_QueueEmpty:
0000A068 42 92              			r1 = 2;							// empty
0000A069 90 9A              			retf;
                            	//.........................................                
                            	
                            	//////////////////////////////////////////////////////
                            	// SACM_GetResource(Address,Page,offset);
                            	//////////////////////////////////////////////////////
                            	
                            	_SP_GetResource:	.PROC
0000A06A 88 DA              			push bp to [sp];
0000A06B 08 0B 01 00        			bp = sp + 1;
                            			//push r2 to [sp];
0000A06D 03 92              			r1 = [bp+3];					// address
0000A06E 04 94              			r2 = [bp+4];					// bank
                            			
0000A06F 5A 95              			r2 = r2 lsl 4;
0000A070 5A 95              			r2 = r2 lsl 4;
0000A071 4A 95              			r2 = r2 lsl 2;
                            			
0000A072 7F BC              			sr &= 0x03f;
0000A073 06 A5              	        r2 |=sr;
0000A074 02 9D              	        sr = r2;
                            	  
0000A075 E1 92              	  		r1 = D:[r1];
                            	       
                            			//pop	r2 from [sp];
0000A076 88 98              			pop	 bp from [sp];
0000A077 90 9A              			retf;
                            			.ENDP 
                            	
                            	_SP_Delay:	.PROC
                            	F_SP_Delay:
                            	
                            	
0000A078 90 9A              			retf;
                            			.ENDP
                            	                
                            	//========================================================================================        
                            	// End of hardware.asm
                            	//========================================================================================
                            	
                            	
                            	
                            	        
                            	        
                            	        
0 error(s), 0 warning(s).

⌨️ 快捷键说明

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