📄 hardware.lst
字号:
00008155 40 F0 B8 81 call F_Delay
00008157 41 94 r2 = 0x0001
00008158 1A D5 12 70 [P_Watchdog_Clear] = r2
0000815A 09 23 40 00 r1 -= 0x40
0000815C 19 D3 17 70 [P_DAC1] = r1
0000815E 09 43 00 80 cmp r1,0x8000
00008160 4C 4E jne L_RU_DownLoop
L_RD_DownEnd:
00008161 0C EE jmp L_RU_End
L_RU_NormalUp:
L_RU_Loop:
00008162 40 F0 B8 81 call F_Delay
00008164 41 94 r2 = 0x0001
00008165 1A D5 12 70 [P_Watchdog_Clear] = r2
00008167 09 03 40 00 r1 += 0x40
00008169 19 D3 17 70 [P_DAC1] = r1
0000816B 09 43 00 80 cmp r1, 0x8000
0000816D 4C 4E jne L_RU_Loop
L_RU_End:
0000816E 90 90 pop r1,r2 from [sp]
0000816F 90 9A retf
.ENDP
//............................................................
_SP_RampDnDAC1: .PROC
F_SP_RampDnDAC1:
00008170 90 D4 push r1,r2 to [sp]
//int off
00008171 11 93 17 70 r1 = [P_DAC1]
00008173 09 B3 C0 FF r1 &= ~0x003F
00008175 0A 5E jz L_RD_End
L_RD_Loop:
00008176 40 F0 B8 81 call F_Delay
00008178 41 94 r2 = 0x0001
00008179 1A D5 12 70 [P_Watchdog_Clear] = r2
0000817B 09 23 40 00 r1 -= 0x40
0000817D 19 D3 17 70 [P_DAC1] = r1
0000817F 4A 4E jnz L_RD_Loop
L_RD_End:
//int fiq,irq
00008180 90 90 pop r1,r2 from [sp]
00008181 90 9A retf
.ENDP
//..............................................................
_SP_RampUpDAC2: .PROC
F_SP_RampUpDAC2:
00008182 90 D4 push r1,r2 to [sp]
00008183 11 93 16 70 r1=[P_DAC2]
00008185 09 B3 C0 FF r1 &= ~0x003f
00008187 09 43 00 80 cmp r1,0x8000
00008189 0E 0E jb L_RU_NormalUp_
0000818A 5D 5E je L_RU_End
L_RU_DownLoop_:
0000818B 40 F0 B8 81 call F_Delay
0000818D 41 94 r2 = 0x0001
0000818E 1A D5 12 70 [P_Watchdog_Clear] = r2
00008190 09 23 40 00 r1 -= 0x40
00008192 19 D3 16 70 [P_DAC2] = r1
00008194 09 43 00 80 cmp r1,0x8000
00008196 4C 4E jne L_RU_DownLoop_
L_RD_DownEnd_:
00008197 0C EE jmp L_RU_End_
L_RU_NormalUp_:
L_RU_Loop_:
00008198 40 F0 B8 81 call F_Delay
0000819A 41 94 r2 = 0x0001
0000819B 1A D5 12 70 [P_Watchdog_Clear] = r2
0000819D 09 03 40 00 r1 += 0x40
0000819F 19 D3 16 70 [P_DAC2] = r1
000081A1 09 43 00 80 cmp r1, 0x8000
000081A3 4C 4E jne L_RU_Loop_
L_RU_End_:
000081A4 90 90 pop r1,r2 from [sp]
000081A5 90 9A retf
.ENDP
//.............................................................
_SP_RampDnDAC2: .PROC
F_SP_RampDnDAC2:
//int off
000081A6 90 D4 push r1,r2 to [sp]
000081A7 11 93 16 70 r1 = [P_DAC2]
000081A9 09 B3 C0 FF r1 &= ~0x003F
000081AB 0A 5E jz L_RD_End_
L_RD_Loop_:
000081AC 40 F0 B8 81 call F_Delay
000081AE 41 94 r2 = 0x0001
000081AF 1A D5 12 70 [P_Watchdog_Clear] = r2
000081B1 09 23 40 00 r1 -= 0x40
000081B3 19 D3 16 70 [P_DAC2] = r1
000081B5 4A 4E jnz L_RD_Loop_
L_RD_End_:
000081B6 90 90 pop r1,r2 from [sp]
000081B7 90 9A retf
.ENDP
//..................................................................
F_Delay:
000081B8 88 D2 push r1 to [sp]
000081B9 50 92 r1 = C_RampDelayTime // Ramp Up/Dn delay per step
L_D_Loop:
000081BA 41 22 r1 -= 1
000081BB 42 4E jnz L_D_Loop
000081BC 88 90 pop r1 from [sp]
000081BD 90 9A RETF
////////////////////////////////////////////////////////////////
// Function: I/O Port A configuration
// void SP_Inti_IOA(int Dir, int Data, int Attrib)
////////////////////////////////////////////////////////////////
_SP_Init_IOA: .PROC
000081BE 88 DA PUSH BP TO [SP]
000081BF 08 0B 01 00 BP = SP + 1
000081C1 88 D2 PUSH R1 TO [SP]
000081C2 03 92 R1 = [BP+3] // Port direction
000081C3 19 D3 02 70 [P_IOA_Dir] = R1
000081C5 04 92 R1 = [BP+4]
000081C6 19 D3 00 70 [P_IOA_Data] = R1
000081C8 05 92 R1 = [BP+5]
000081C9 19 D3 03 70 [P_IOA_Attrib] = R1
000081CB 88 90 POP R1 FROM [SP]
000081CC 88 98 POP BP FROM [SP]
000081CD 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: I/O Port B configuration
// void SP_Inti_IOB(int Dir, int Data, int Attrib)
//////////////////////////////////////////////////////////////////
_SP_Init_IOB: .PROC
000081CE 88 DA PUSH BP TO [SP]
000081CF 08 0B 01 00 BP = SP + 1
000081D1 88 D2 PUSH R1 TO [SP]
000081D2 03 92 R1 = [BP+3] // Port direction
000081D3 19 D3 07 70 [P_IOB_Dir] = R1
000081D5 04 92 R1 = [BP+4]
000081D6 19 D3 05 70 [P_IOB_Data] = R1
000081D8 05 92 R1 = [BP+5]
000081D9 19 D3 08 70 [P_IOB_Attrib] = R1
000081DB 88 90 POP R1 FROM [SP]
000081DC 88 98 POP BP FROM [SP]
000081DD 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: Get data from port
// int SP_Import(unsigned int Port)
//////////////////////////////////////////////////////////////////
_SP_Import: .PROC
000081DE 88 DA PUSH BP TO [SP]
000081DF 08 0B 01 00 BP = SP + 1
000081E1 03 92 R1 = [BP+3] // Port Number
000081E2 C1 92 R1 = [R1]
000081E3 88 98 POP BP FROM [SP]
000081E4 90 9A RETF
.ENDP
_SP_Export: .PROC
000081E5 88 DA PUSH BP,BP TO [SP]
000081E6 08 0B 01 00 BP = SP + 1
000081E8 90 D4 PUSH R1,R2 TO [SP]
000081E9 03 92 R1 = [BP+3] // Port Number
000081EA 04 94 R2 = [BP+4] // Value
000081EB C1 D4 [R1] = R2
000081EC 90 90 POP R1,R2 FROM [SP]
000081ED 88 98 POP BP,BP FROM [SP]
000081EE 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: Get data from resource(ROM area)
// int SP_GetResource(int Addr, int Page)
//////////////////////////////////////////////////////////////////
_SP_GetResource: .PROC
000081EF 88 DA push bp to [sp]
000081F0 08 0B 01 00 bp = sp + 1
000081F2 03 92 r1 = [bp+3] // Address
000081F3 04 94 r2 = [bp+4] // Page
000081F4 5A 95 r2 = r2 lsl 4 // Prepare Page for SR
000081F5 5A 95 r2 = r2 lsl 4
000081F6 4A 95 r2 = r2 lsl 2
000081F7 7F BC sr &= 0x03f // Change Page
000081F8 06 A5 r2 |=sr //
000081F9 02 9D sr = r2 //
000081FA E1 92 r1 = D:[r1] // Get data
000081FB 88 98 pop bp from [sp]
000081FC 90 9A retf
.ENDP
//........................................
F_SP_GetResource:
000081FD 5A 95 r2 = r2 lsl 4 // Prepare Page for SR
000081FE 5A 95 r2 = r2 lsl 4
000081FF 4A 95 r2 = r2 lsl 2
00008200 7F BC sr &= 0x03f // Change Page
00008201 06 A5 r2 |=sr //
00008202 02 9D sr = r2 //
00008203 E1 92 r1 = D:[r1] // Get data
00008204 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
//////////////////////////////////////////////////////////////////
.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 + -