📄 hardware.lst
字号:
00008EEF 09 43 00 80 cmp r1,0x8000
00008EF1 4C 4E jne L_RU_DownLoop
L_RD_DownEnd:
00008EF2 0C EE jmp L_RU_End
L_RU_NormalUp:
L_RU_Loop:
00008EF3 40 F0 49 8F call F_Delay
00008EF5 41 94 r2 = 0x0001
00008EF6 1A D5 12 70 [P_Watchdog_Clear] = r2
00008EF8 09 03 40 00 r1 += 0x40
00008EFA 19 D3 17 70 [P_DAC1] = r1
00008EFC 09 43 00 80 cmp r1, 0x8000
00008EFE 4C 4E jne L_RU_Loop
L_RU_End:
00008EFF 90 90 pop r1,r2 from [sp]
00008F00 90 9A retf
.ENDP
//............................................................
_SP_RampDnDAC1: .PROC
F_SP_RampDnDAC1:
00008F01 90 D4 push r1,r2 to [sp]
//int off
00008F02 11 93 17 70 r1 = [P_DAC1]
00008F04 09 B3 C0 FF r1 &= ~0x003F
00008F06 0A 5E jz L_RD_End
L_RD_Loop:
00008F07 40 F0 49 8F call F_Delay
00008F09 41 94 r2 = 0x0001
00008F0A 1A D5 12 70 [P_Watchdog_Clear] = r2
00008F0C 09 23 40 00 r1 -= 0x40
00008F0E 19 D3 17 70 [P_DAC1] = r1
00008F10 4A 4E jnz L_RD_Loop
L_RD_End:
//int fiq,irq
00008F11 90 90 pop r1,r2 from [sp]
00008F12 90 9A retf
.ENDP
//..............................................................
_SP_RampUpDAC2: .PROC
F_SP_RampUpDAC2:
00008F13 90 D4 push r1,r2 to [sp]
00008F14 11 93 16 70 r1=[P_DAC2]
00008F16 09 B3 C0 FF r1 &= ~0x003f
00008F18 09 43 00 80 cmp r1,0x8000
00008F1A 0E 0E jb L_RU_NormalUp_
00008F1B 5D 5E je L_RU_End
L_RU_DownLoop_:
00008F1C 40 F0 49 8F call F_Delay
00008F1E 41 94 r2 = 0x0001
00008F1F 1A D5 12 70 [P_Watchdog_Clear] = r2
00008F21 09 23 40 00 r1 -= 0x40
00008F23 19 D3 16 70 [P_DAC2] = r1
00008F25 09 43 00 80 cmp r1,0x8000
00008F27 4C 4E jne L_RU_DownLoop_
L_RD_DownEnd_:
00008F28 0C EE jmp L_RU_End_
L_RU_NormalUp_:
L_RU_Loop_:
00008F29 40 F0 49 8F call F_Delay
00008F2B 41 94 r2 = 0x0001
00008F2C 1A D5 12 70 [P_Watchdog_Clear] = r2
00008F2E 09 03 40 00 r1 += 0x40
00008F30 19 D3 16 70 [P_DAC2] = r1
00008F32 09 43 00 80 cmp r1, 0x8000
00008F34 4C 4E jne L_RU_Loop_
L_RU_End_:
00008F35 90 90 pop r1,r2 from [sp]
00008F36 90 9A retf
.ENDP
//.............................................................
_SP_RampDnDAC2: .PROC
F_SP_RampDnDAC2:
//int off
00008F37 90 D4 push r1,r2 to [sp]
00008F38 11 93 16 70 r1 = [P_DAC2]
00008F3A 09 B3 C0 FF r1 &= ~0x003F
00008F3C 0A 5E jz L_RD_End_
L_RD_Loop_:
00008F3D 40 F0 49 8F call F_Delay
00008F3F 41 94 r2 = 0x0001
00008F40 1A D5 12 70 [P_Watchdog_Clear] = r2
00008F42 09 23 40 00 r1 -= 0x40
00008F44 19 D3 16 70 [P_DAC2] = r1
00008F46 4A 4E jnz L_RD_Loop_
L_RD_End_:
00008F47 90 90 pop r1,r2 from [sp]
00008F48 90 9A retf
.ENDP
//..................................................................
F_Delay:
00008F49 88 D2 push r1 to [sp]
00008F4A 60 92 r1 = C_RampDelayTime // Ramp Up/Dn delay per step
L_D_Loop:
00008F4B 41 22 r1 -= 1
00008F4C 42 4E jnz L_D_Loop
00008F4D 88 90 pop r1 from [sp]
00008F4E 90 9A RETF
////////////////////////////////////////////////////////////////
// Function: I/O Port A configuration
// void SP_Inti_IOA(int Dir, int Data, int Attrib)
////////////////////////////////////////////////////////////////
_SP_Init_IOA: .PROC
00008F4F 88 DA PUSH bp TO [sp]
00008F50 08 0B 01 00 bp = sp + 1
00008F52 88 D2 PUSH r1 TO [sp]
00008F53 03 92 r1 = [bp+3] // Port direction
00008F54 19 D3 02 70 [P_IOA_Dir] = r1
00008F56 04 92 r1 = [bp+4]
00008F57 19 D3 00 70 [P_IOA_Data] = r1
00008F59 05 92 r1 = [bp+5]
00008F5A 19 D3 03 70 [P_IOA_Attrib] = r1
00008F5C 88 90 POP r1 FROM [sp]
00008F5D 88 98 POP bp FROM [sp]
00008F5E 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: I/O Port B configuration
// void SP_Inti_IOB(int Dir, int Data, int Attrib)
//////////////////////////////////////////////////////////////////
_SP_Init_IOB: .PROC
00008F5F 88 DA PUSH bp TO [sp]
00008F60 08 0B 01 00 bp = sp + 1
00008F62 88 D2 PUSH r1 TO [sp]
00008F63 03 92 r1 = [bp+3] // Port direction
00008F64 19 D3 07 70 [P_IOB_Dir] = r1
00008F66 04 92 r1 = [bp+4]
00008F67 19 D3 05 70 [P_IOB_Data] = r1
00008F69 05 92 r1 = [bp+5]
00008F6A 19 D3 08 70 [P_IOB_Attrib] = r1
00008F6C 88 90 POP r1 FROM [sp]
00008F6D 88 98 POP bp FROM [sp]
00008F6E 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: Get data from port
// int SP_Import(unsigned int Port)
//////////////////////////////////////////////////////////////////
_SP_Import: .PROC
00008F6F 88 DA PUSH bp TO [sp]
00008F70 08 0B 01 00 bp = sp + 1
00008F72 03 92 r1 = [bp+3] // Port Number
00008F73 C1 92 r1 = [r1]
00008F74 88 98 POP bp FROM [sp]
00008F75 90 9A RETF
.ENDP
_SP_Export: .PROC
00008F76 88 DA PUSH bp,bp TO [sp]
00008F77 41 00 sp = sp + 1
00008F78 90 D4 PUSH r1,r2 TO [sp]
00008F79 03 92 r1 = [bp+3] // Port Number
00008F7A 04 94 r2 = [bp+4] // Value
00008F7B C1 D4 [r1] = r2
00008F7C 90 90 POP r1,r2 FROM [sp]
00008F7D 88 98 POP bp,bp FROM [sp]
00008F7E 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: Get data from resource(ROM area)
// int SP_GetResource(int Addr, int Page)
//////////////////////////////////////////////////////////////////
_SP_GetResource: .PROC
00008F7F 88 DA push bp to [sp]
00008F80 08 0B 01 00 bp = sp + 1
00008F82 03 92 r1 = [bp+3] // Address
00008F83 04 94 r2 = [bp+4] // Page
00008F84 5A 95 r2 = r2 lsl 4 // Prepare Page for SR
00008F85 5A 95 r2 = r2 lsl 4
00008F86 4A 95 r2 = r2 lsl 2
00008F87 7F BC sr &= 0x03f // Change Page
00008F88 06 A5 r2 |=sr //
00008F89 02 9D sr = r2 //
00008F8A E1 92 r1 = D:[r1] // Get data
00008F8B 88 98 pop bp from [sp]
00008F8C 90 9A retf
.ENDP
//........................................
F_SP_GetResource:
00008F8D 5A 95 r2 = r2 lsl 4 // Prepare Page for SR
00008F8E 5A 95 r2 = r2 lsl 4
00008F8F 4A 95 r2 = r2 lsl 2
00008F90 7F BC sr &= 0x03f // Change Page
00008F91 06 A5 r2 |=sr //
00008F92 02 9D sr = r2 //
00008F93 E1 92 r1 = D:[r1] // Get data
00008F94 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 + -