📄 hardware.lst
字号:
L_RU_NormalUp:
L_RU_Loop:
00008400 40 F0 56 84 call F_Delay
00008402 41 94 r2 = 0x0001
00008403 1A D5 12 70 [P_Watchdog_Clear] = r2
00008405 09 03 40 00 r1 += 0x40
00008407 19 D3 17 70 [P_DAC1] = r1
00008409 09 43 00 80 cmp r1, 0x8000
0000840B 4C 4E jne L_RU_Loop
L_RU_End:
0000840C 90 90 pop r1,r2 from [sp]
0000840D 90 9A retf
.ENDP
//............................................................
_SP_RampDnDAC1: .PROC
F_SP_RampDnDAC1:
0000840E 90 D4 push r1,r2 to [sp]
//int off
0000840F 11 93 17 70 r1 = [P_DAC1]
00008411 09 B3 C0 FF r1 &= ~0x003F
00008413 0A 5E jz L_RD_End
L_RD_Loop:
00008414 40 F0 56 84 call F_Delay
00008416 41 94 r2 = 0x0001
00008417 1A D5 12 70 [P_Watchdog_Clear] = r2
00008419 09 23 40 00 r1 -= 0x40
0000841B 19 D3 17 70 [P_DAC1] = r1
0000841D 4A 4E jnz L_RD_Loop
L_RD_End:
//int fiq,irq
0000841E 90 90 pop r1,r2 from [sp]
0000841F 90 9A retf
.ENDP
//..............................................................
_SP_RampUpDAC2: .PROC
F_SP_RampUpDAC2:
00008420 90 D4 push r1,r2 to [sp]
00008421 11 93 16 70 r1=[P_DAC2]
00008423 09 B3 C0 FF r1 &= ~0x003f
00008425 09 43 00 80 cmp r1,0x8000
00008427 0E 0E jb L_RU_NormalUp_
00008428 5D 5E je L_RU_End
L_RU_DownLoop_:
00008429 40 F0 56 84 call F_Delay
0000842B 41 94 r2 = 0x0001
0000842C 1A D5 12 70 [P_Watchdog_Clear] = r2
0000842E 09 23 40 00 r1 -= 0x40
00008430 19 D3 16 70 [P_DAC2] = r1
00008432 09 43 00 80 cmp r1,0x8000
00008434 4C 4E jne L_RU_DownLoop_
L_RD_DownEnd_:
00008435 0C EE jmp L_RU_End_
L_RU_NormalUp_:
L_RU_Loop_:
00008436 40 F0 56 84 call F_Delay
00008438 41 94 r2 = 0x0001
00008439 1A D5 12 70 [P_Watchdog_Clear] = r2
0000843B 09 03 40 00 r1 += 0x40
0000843D 19 D3 16 70 [P_DAC2] = r1
0000843F 09 43 00 80 cmp r1, 0x8000
00008441 4C 4E jne L_RU_Loop_
L_RU_End_:
00008442 90 90 pop r1,r2 from [sp]
00008443 90 9A retf
.ENDP
//.............................................................
_SP_RampDnDAC2: .PROC
F_SP_RampDnDAC2:
//int off
00008444 90 D4 push r1,r2 to [sp]
00008445 11 93 16 70 r1 = [P_DAC2]
00008447 09 B3 C0 FF r1 &= ~0x003F
00008449 0A 5E jz L_RD_End_
L_RD_Loop_:
0000844A 40 F0 56 84 call F_Delay
0000844C 41 94 r2 = 0x0001
0000844D 1A D5 12 70 [P_Watchdog_Clear] = r2
0000844F 09 23 40 00 r1 -= 0x40
00008451 19 D3 16 70 [P_DAC2] = r1
00008453 4A 4E jnz L_RD_Loop_
L_RD_End_:
00008454 90 90 pop r1,r2 from [sp]
00008455 90 9A retf
.ENDP
//..................................................................
F_Delay:
00008456 88 D2 push r1 to [sp]
00008457 50 92 r1 = C_RampDelayTime // Ramp Up/Dn delay per step
L_D_Loop:
00008458 41 22 r1 -= 1
00008459 42 4E jnz L_D_Loop
0000845A 88 90 pop r1 from [sp]
0000845B 90 9A RETF
////////////////////////////////////////////////////////////////
// Function: I/O Port A configuration
// void SP_Inti_IOA(int Dir, int Data, int Attrib)
////////////////////////////////////////////////////////////////
_SP_Init_IOA: .PROC
0000845C 88 DA PUSH BP TO [SP]
0000845D 08 0B 01 00 BP = SP + 1
0000845F 88 D2 PUSH R1 TO [SP]
00008460 03 92 R1 = [BP+3] // Port direction
00008461 19 D3 02 70 [P_IOA_Dir] = R1
00008463 04 92 R1 = [BP+4]
00008464 19 D3 00 70 [P_IOA_Data] = R1
00008466 05 92 R1 = [BP+5]
00008467 19 D3 03 70 [P_IOA_Attrib] = R1
00008469 88 90 POP R1 FROM [SP]
0000846A 88 98 POP BP FROM [SP]
0000846B 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: I/O Port B configuration
// void SP_Inti_IOB(int Dir, int Data, int Attrib)
//////////////////////////////////////////////////////////////////
_SP_Init_IOB: .PROC
0000846C 88 DA PUSH BP TO [SP]
0000846D 08 0B 01 00 BP = SP + 1
0000846F 88 D2 PUSH R1 TO [SP]
00008470 03 92 R1 = [BP+3] // Port direction
00008471 19 D3 07 70 [P_IOB_Dir] = R1
00008473 04 92 R1 = [BP+4]
00008474 19 D3 05 70 [P_IOB_Data] = R1
00008476 05 92 R1 = [BP+5]
00008477 19 D3 08 70 [P_IOB_Attrib] = R1
00008479 88 90 POP R1 FROM [SP]
0000847A 88 98 POP BP FROM [SP]
0000847B 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: Get data from port
// int SP_Import(unsigned int Port)
//////////////////////////////////////////////////////////////////
_SP_Import: .PROC
0000847C 88 DA PUSH BP TO [SP]
0000847D 08 0B 01 00 BP = SP + 1
0000847F 03 92 R1 = [BP+3] // Port Number
00008480 C1 92 R1 = [R1]
00008481 88 98 POP BP FROM [SP]
00008482 90 9A RETF
.ENDP
_SP_Export: .PROC
00008483 88 DA PUSH BP,BP TO [SP]
00008484 08 0B 01 00 BP = SP + 1
00008486 90 D4 PUSH R1,R2 TO [SP]
00008487 03 92 R1 = [BP+3] // Port Number
00008488 04 94 R2 = [BP+4] // Value
00008489 C1 D4 [R1] = R2
0000848A 90 90 POP R1,R2 FROM [SP]
0000848B 88 98 POP BP,BP FROM [SP]
0000848C 90 9A RETF
.ENDP
//////////////////////////////////////////////////////////////////
// Function: Get data from resource(ROM area)
// int SP_GetResource(int Addr, int Page)
//////////////////////////////////////////////////////////////////
_SP_GetResource: .PROC
0000848D 88 DA push bp to [sp]
0000848E 08 0B 01 00 bp = sp + 1
00008490 03 92 r1 = [bp+3] // Address
00008491 04 94 r2 = [bp+4] // Page
00008492 5A 95 r2 = r2 lsl 4 // Prepare Page for SR
00008493 5A 95 r2 = r2 lsl 4
00008494 4A 95 r2 = r2 lsl 2
00008495 7F BC sr &= 0x03f // Change Page
00008496 06 A5 r2 |=sr //
00008497 02 9D sr = r2 //
00008498 E1 92 r1 = D:[r1] // Get data
00008499 88 98 pop bp from [sp]
0000849A 90 9A retf
.ENDP
//........................................
F_SP_GetResource:
0000849B 5A 95 r2 = r2 lsl 4 // Prepare Page for SR
0000849C 5A 95 r2 = r2 lsl 4
0000849D 4A 95 r2 = r2 lsl 2
0000849E 7F BC sr &= 0x03f // Change Page
0000849F 06 A5 r2 |=sr //
000084A0 02 9D sr = r2 //
000084A1 E1 92 r1 = D:[r1] // Get data
000084A2 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 + -