📄 hardware.lst
字号:
00009F93 09 43 00 80 cmp r1,0x8000
00009F95 4C 4E jne L_RU_DownLoop
L_RD_DownEnd:
00009F96 0C EE jmp L_RU_End
L_RU_NormalUp:
L_RU_Loop:
00009F97 40 F0 ED 9F call F_Delay
00009F99 41 94 r2 = 0x0001
00009F9A 1A D5 12 70 [P_Watchdog_Clear] = r2
00009F9C 09 03 40 00 r1 += 0x40
00009F9E 19 D3 17 70 [P_DAC1] = r1
00009FA0 09 43 00 80 cmp r1, 0x8000
00009FA2 4C 4E jne L_RU_Loop
L_RU_End:
00009FA3 90 90 pop r1,r2 from [sp]
00009FA4 90 9A retf
.ENDP
//............................................................
_SP_RampDnDAC1: .PROC
F_SP_RampDnDAC1:
00009FA5 90 D4 push r1,r2 to [sp]
//int off
00009FA6 11 93 17 70 r1 = [P_DAC1]
00009FA8 09 B3 C0 FF r1 &= ~0x003F
00009FAA 0A 5E jz L_RD_End
L_RD_Loop:
00009FAB 40 F0 ED 9F call F_Delay
00009FAD 41 94 r2 = 0x0001
00009FAE 1A D5 12 70 [P_Watchdog_Clear] = r2
00009FB0 09 23 40 00 r1 -= 0x40
00009FB2 19 D3 17 70 [P_DAC1] = r1
00009FB4 4A 4E jnz L_RD_Loop
L_RD_End:
//int fiq,irq
00009FB5 90 90 pop r1,r2 from [sp]
00009FB6 90 9A retf
.ENDP
//..............................................................
_SP_RampUpDAC2: .PROC
F_SP_RampUpDAC2:
00009FB7 90 D4 push r1,r2 to [sp]
00009FB8 11 93 16 70 r1=[P_DAC2]
00009FBA 09 B3 C0 FF r1 &= ~0x003f
00009FBC 09 43 00 80 cmp r1,0x8000
00009FBE 0E 0E jb L_RU_NormalUp_
00009FBF 5D 5E je L_RU_End
L_RU_DownLoop_:
00009FC0 40 F0 ED 9F call F_Delay
00009FC2 41 94 r2 = 0x0001
00009FC3 1A D5 12 70 [P_Watchdog_Clear] = r2
00009FC5 09 23 40 00 r1 -= 0x40
00009FC7 19 D3 16 70 [P_DAC2] = r1
00009FC9 09 43 00 80 cmp r1,0x8000
00009FCB 4C 4E jne L_RU_DownLoop_
L_RD_DownEnd_:
00009FCC 0C EE jmp L_RU_End_
L_RU_NormalUp_:
L_RU_Loop_:
00009FCD 40 F0 ED 9F call F_Delay
00009FCF 41 94 r2 = 0x0001
00009FD0 1A D5 12 70 [P_Watchdog_Clear] = r2
00009FD2 09 03 40 00 r1 += 0x40
00009FD4 19 D3 16 70 [P_DAC2] = r1
00009FD6 09 43 00 80 cmp r1, 0x8000
00009FD8 4C 4E jne L_RU_Loop_
L_RU_End_:
00009FD9 90 90 pop r1,r2 from [sp]
00009FDA 90 9A retf
.ENDP
//.............................................................
_SP_RampDnDAC2: .PROC
F_SP_RampDnDAC2:
//int off
00009FDB 90 D4 push r1,r2 to [sp]
00009FDC 11 93 16 70 r1 = [P_DAC2]
00009FDE 09 B3 C0 FF r1 &= ~0x003F
00009FE0 0A 5E jz L_RD_End_
L_RD_Loop_:
00009FE1 40 F0 ED 9F call F_Delay
00009FE3 41 94 r2 = 0x0001
00009FE4 1A D5 12 70 [P_Watchdog_Clear] = r2
00009FE6 09 23 40 00 r1 -= 0x40
00009FE8 19 D3 16 70 [P_DAC2] = r1
00009FEA 4A 4E jnz L_RD_Loop_
L_RD_End_:
00009FEB 90 90 pop r1,r2 from [sp]
00009FEC 90 9A retf
.ENDP
//..................................................................
F_Delay:
00009FED 88 D2 push r1 to [sp]
00009FEE 60 92 r1 = C_RampDelayTime // Ramp Up/Dn delay per step
L_D_Loop:
00009FEF 41 22 r1 -= 1
00009FF0 42 4E jnz L_D_Loop
00009FF1 88 90 pop r1 from [sp]
00009FF2 90 9A RETF
////////////////////////////////////////////////////////////////
// Function: I/O Port A configuration
// void SP_Inti_IOA(int Dir, int Data, int Attrib)
////////////////////////////////////////////////////////////////
_SP_Init_IOA: .PROC
00009FF3 88 DA PUSH BP TO [SP]
00009FF4 08 0B 01 00 BP = SP + 1
00009FF6 88 D2 PUSH R1 TO [SP]
00009FF7 03 92 R1 = [BP+3] // Port direction
00009FF8 19 D3 02 70 [P_IOA_Dir] = R1
00009FFA 04 92 R1 = [BP+4]
00009FFB 19 D3 00 70 [P_IOA_Data] = R1
00009FFD 05 92 R1 = [BP+5]
00009FFE 19 D3 03 70 [P_IOA_Attrib] = R1
0000A000 88 90 POP R1 FROM [SP]
0000A001 88 98 POP BP FROM [SP]
0000A002 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: I/O Port B configuration
// void SP_Inti_IOB(int Dir, int Data, int Attrib)
//////////////////////////////////////////////////////////////////
_SP_Init_IOB: .PROC
0000A003 88 DA PUSH BP TO [SP]
0000A004 08 0B 01 00 BP = SP + 1
0000A006 88 D2 PUSH R1 TO [SP]
0000A007 03 92 R1 = [BP+3] // Port direction
0000A008 19 D3 07 70 [P_IOB_Dir] = R1
0000A00A 04 92 R1 = [BP+4]
0000A00B 19 D3 05 70 [P_IOB_Data] = R1
0000A00D 05 92 R1 = [BP+5]
0000A00E 19 D3 08 70 [P_IOB_Attrib] = R1
0000A010 88 90 POP R1 FROM [SP]
0000A011 88 98 POP BP FROM [SP]
0000A012 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: Get data from port
// int SP_Import(unsigned int Port)
//////////////////////////////////////////////////////////////////
_SP_Import: .PROC
0000A013 88 DA PUSH BP TO [SP]
0000A014 08 0B 01 00 BP = SP + 1
0000A016 03 92 R1 = [BP+3] // Port Number
0000A017 C1 92 R1 = [R1]
0000A018 88 98 POP BP FROM [SP]
0000A019 90 9A RETF
.ENDP
_SP_Export: .PROC
0000A01A 88 DA PUSH BP,BP TO [SP]
0000A01B 08 0B 01 00 BP = SP + 1
0000A01D 90 D4 PUSH R1,R2 TO [SP]
0000A01E 03 92 R1 = [BP+3] // Port Number
0000A01F 04 94 R2 = [BP+4] // Value
0000A020 C1 D4 [R1] = R2
0000A021 90 90 POP R1,R2 FROM [SP]
0000A022 88 98 POP BP,BP FROM [SP]
0000A023 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: Get data from resource(ROM area)
// int SP_GetResource(int Addr, int Page)
//////////////////////////////////////////////////////////////////
_SP_GetResource: .PROC
0000A024 88 DA push bp to [sp]
0000A025 08 0B 01 00 bp = sp + 1
0000A027 03 92 r1 = [bp+3] // Address
0000A028 04 94 r2 = [bp+4] // Page
0000A029 5A 95 r2 = r2 lsl 4 // Prepare Page for SR
0000A02A 5A 95 r2 = r2 lsl 4
0000A02B 4A 95 r2 = r2 lsl 2
0000A02C 7F BC sr &= 0x03f // Change Page
0000A02D 06 A5 r2 |=sr //
0000A02E 02 9D sr = r2 //
0000A02F E1 92 r1 = D:[r1] // Get data
0000A030 88 98 pop bp from [sp]
0000A031 90 9A retf
.ENDP
//........................................
F_SP_GetResource:
0000A032 5A 95 r2 = r2 lsl 4 // Prepare Page for SR
0000A033 5A 95 r2 = r2 lsl 4
0000A034 4A 95 r2 = r2 lsl 2
0000A035 7F BC sr &= 0x03f // Change Page
0000A036 06 A5 r2 |=sr //
0000A037 02 9D sr = r2 //
0000A038 E1 92 r1 = D:[r1] // Get data
0000A039 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 + -