apple2_print_uint16/print_uint16.s

96 lines
2.3 KiB
ArmAsm
Raw Normal View History

2017-07-05 19:38:09 -07:00
; Michael Pohoreski
2017-07-06 07:58:22 -07:00
; https://github.com/Michaelangel007/apple2_print_uint16
2017-07-05 19:38:09 -07:00
; Optimized from printm
; Thanks to qkumba for optimizations
2017-07-06 07:58:22 -07:00
; Thanks to gid for nudging a zero-page version
2017-07-05 19:38:09 -07:00
; F8 ROM Entry Points
2017-07-05 18:50:13 -07:00
COUT = $FDED
SCRN2 = $F879
2017-07-05 16:42:22 -07:00
ORG $800
LDA #$12
LDX #$34
JMP PrintUint16
2017-07-05 16:42:22 -07:00
; Print unsigned 16-bit integer
; A=High byte
; X=Low byte
; Also see: Applesoft LINPRT @ ED24
2017-07-05 16:42:22 -07:00
; ======================================================================
PrintUint16
2017-07-05 23:08:47 -07:00
STX _temp
PHA ; Optimized: STA _temp+1
2017-07-05 16:42:22 -07:00
2017-07-05 23:08:47 -07:00
LDX #0
STX _bcd+0
STX _bcd+1
STX _bcd+2
2017-07-05 16:42:22 -07:00
Dec2BCD
LDX #16 ; 16 bits
SED ; "Double Dabble"
_Dec2BCD ; https://en.wikipedia.org/wiki/Double_dabble
2017-07-05 23:08:47 -07:00
ASL _temp+0 ; abcd efgh | ijkl mnop |
; ROL _temp+1 ; C=a bcde fghi | jklm nop0 |
; ; Bit 7654_3210 | 7654_3210 |
PLA
ROL
PHA
2017-07-05 16:42:22 -07:00
LDY #$FD ; $00-$FD=-3 bcd[0] bcd[1] bcd[2] bcd[3]
_DoubleDabble ; Y=FD Y=FE Y=FF Y=00
LDA _bcd-$FD,Y
ADC _bcd-$FD,Y
STA _bcd-$FD,Y
INY
BNE _DoubleDabble
DEX
BNE _Dec2BCD
2017-07-05 23:08:47 -07:00
PLA ; keep stack
2017-07-05 18:50:13 -07:00
CLD ; X=0 = output length
2017-07-05 16:42:22 -07:00
DecWidth
2017-07-05 20:28:10 -07:00
LDY #3 ; maximum 6 digits output
2017-07-05 16:42:22 -07:00
BCD2Chars
2017-07-05 19:38:09 -07:00
LDA _bcd-1,Y
2017-07-05 20:28:10 -07:00
JSR HexA ; print 0, 1, or 2 hex digits
2017-07-05 16:42:22 -07:00
DEY
2017-07-05 19:38:09 -07:00
BNE BCD2Chars
2017-07-05 16:42:22 -07:00
2017-07-05 23:08:47 -07:00
TXA ; Handle special case input = $0000 of no output
2017-07-06 07:58:22 -07:00
BEQ _HaveLeadingDigit
2017-07-05 18:50:13 -07:00
2017-07-05 16:42:22 -07:00
_PrintDone
RTS
2017-07-05 20:32:41 -07:00
; Converts A to high ASCII digits, prints as they become available
2017-07-05 19:45:51 -07:00
; @return: A will be bottom nibble in high ASCII
2017-07-05 16:42:22 -07:00
HexA
PHA
2017-07-05 18:50:13 -07:00
JSR SCRN2+2 ; LSR x4 == 0>> 4
2017-07-05 16:42:22 -07:00
JSR _HexNib
PLA
2017-07-05 18:50:13 -07:00
AND #$F
2017-07-05 16:42:22 -07:00
_HexNib
2017-07-05 19:38:09 -07:00
BNE _HaveLeadingDigit ; If have leading zero and no output yet ...
CPX #0 ; ... then skip storing it
2017-07-05 22:27:57 -07:00
BEQ _PrintDone
2017-07-05 19:38:09 -07:00
_HaveLeadingDigit
2017-07-05 16:42:22 -07:00
CMP #$A ; n < 10 ?
BCC _Hex2Asc
ADC #6 ; n += 6 $A -> +6 + (C=1) = $11
_Hex2Asc
ADC #'0' + $80 ; inverse=remove #$80
PutChar
2017-07-05 18:50:13 -07:00
INX ; X = output string length
2017-07-05 22:27:57 -07:00
JMP COUT
2017-07-05 16:42:22 -07:00
2017-07-06 07:58:22 -07:00
_bcd ds 3 ; 6 chars for printing dec
2017-07-05 23:08:47 -07:00
_temp db 0
2017-07-05 16:42:22 -07:00