Line 1... |
Line 1... |
3 error(s), 526 warning(s) unlisted in pass 1
|
3 error(s), 894 warning(s) unlisted in pass 1
|
; ============================================================================
|
; ============================================================================
|
; __
|
; __
|
; \\__/ o\ (C) 2013-2022 Robert Finch, Waterloo
|
; \\__/ o\ (C) 2013-2022 Robert Finch, Waterloo
|
; \ __ / All rights reserved.
|
; \ __ / All rights reserved.
|
; \/_// robfinch@opencores.org
|
; \/_// robfinch@opencores.org
|
Line 69... |
Line 69... |
; OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
; OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
; OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
; OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
;
|
;
|
; ============================================================================
|
; ============================================================================
|
;
|
;
|
|
; ASCII control characters.
|
|
SOH equ 1
|
|
EOT equ 4
|
|
ACK equ 6
|
|
BS equ 8
|
|
NAK equ 21
|
|
ETB equ $17
|
|
CAN equ 24
|
|
DEL equ 127
|
|
|
CR EQU $0D ;ASCII equates
|
CR EQU $0D ;ASCII equates
|
LF EQU $0A
|
LF EQU $0A
|
TAB EQU $09
|
TAB EQU $09
|
CTRLC EQU $03
|
CTRLC EQU $03
|
CTRLH EQU $08
|
CTRLH EQU $08
|
Line 104... |
Line 114... |
MF_Srand EQU 8
|
MF_Srand EQU 8
|
MF_Random EQU 9
|
MF_Random EQU 9
|
MF_OSCALL EQU 10
|
MF_OSCALL EQU 10
|
MF_GetRange EQU 11 ; gets a pair of numbers last>first
|
MF_GetRange EQU 11 ; gets a pair of numbers last>first
|
MF_GetNumber EQU 12
|
MF_GetNumber EQU 12
|
|
MF_SerialPutchar EQU 13
|
|
|
mon_numwka EQU $910
|
mon_numwka EQU $910
|
mon_r1 EQU $920
|
mon_r1 EQU $920
|
mon_r2 EQU $924
|
mon_r2 EQU $924
|
; ============================================================================
|
; ============================================================================
|
Line 170... |
Line 181... |
ACIA_TX EQU 0
|
ACIA_TX EQU 0
|
ACIA_RX EQU 0
|
ACIA_RX EQU 0
|
ACIA_STAT EQU 1
|
ACIA_STAT EQU 1
|
ACIA_CMD EQU 2
|
ACIA_CMD EQU 2
|
ACIA_CTRL EQU 3
|
ACIA_CTRL EQU 3
|
|
ACIA_IRQS EQU 4
|
ACIA_CTRL2 EQU 11
|
ACIA_CTRL2 EQU 11
|
RTC EQU $FFFE30500 ; I2C
|
RTC EQU $FFFE30500 ; I2C
|
RTCBuf EQU $7FC0
|
RTCBuf EQU $7FC0
|
PRNG EQU $FFFE30600
|
PRNG EQU $FFFE30600
|
KEYBD EQU $FFFE30400
|
KEYBD EQU $FFFE30400
|
Line 239... |
Line 251... |
IOFocusList EQU $FFC000 ; to $FF000F
|
IOFocusList EQU $FFC000 ; to $FF000F
|
IOFocusID EQU $FFC010
|
IOFocusID EQU $FFC010
|
IrqSource EQU $FFC011
|
IrqSource EQU $FFC011
|
IRQFlag EQU $FFC012
|
IRQFlag EQU $FFC012
|
RunningID EQU $FFC013
|
RunningID EQU $FFC013
|
|
milliseconds EQU $FFC014
|
|
|
|
; One copy of serial buffer management
|
|
; 1 serial buffer for system.
|
|
SerHeadRcv EQU $FFC015
|
|
SerTailRcv EQU $FFC016
|
|
SerHeadXmit EQU $FFC017
|
|
SerTailXmit EQU $FFC018
|
|
SerRcvXon EQU $FFC019
|
|
SerRcvXoff EQU $FFC01A
|
|
SerRcvBuf EQU $FFB000 ; 4kB serial recieve buffer
|
|
|
; Top of boot stack is at $FFC0FF
|
; Top of boot stack is at $FFC0FF
|
|
|
; These variables use direct page access
|
; These variables use direct page access
|
CursorRow EQU $110
|
CursorRow EQU $110
|
CursorCol EQU $111
|
CursorCol EQU $111
|
Line 257... |
Line 281... |
kbdHeadRcv EQU $127
|
kbdHeadRcv EQU $127
|
kbdTailRcv EQU $128
|
kbdTailRcv EQU $128
|
kbdFifo EQU $40 ; in local RAM
|
kbdFifo EQU $40 ; in local RAM
|
kbdFifoAlias EQU $C00040 ; to $C0007F ; alias for $40 to $7F
|
kbdFifoAlias EQU $C00040 ; to $C0007F ; alias for $40 to $7F
|
SerhZero EQU $130
|
SerhZero EQU $130
|
SerHeadRcv EQU $131
|
|
SertZero EQU $132
|
SertZero EQU $132
|
SerTailRcv EQU $133
|
|
SerHeadXmit EQU $136
|
|
SerTailXmit EQU $138
|
|
SerRcvXon EQU $139
|
|
SerRcvXoff EQU $140
|
|
SerRcvBuf EQU $BFF000 ; 4kB serial recieve buffer
|
|
|
|
farflag EQU $15F
|
farflag EQU $15F
|
asmbuf EQU $160 ; to $17F
|
asmbuf EQU $160 ; to $17F
|
|
|
QNdx0 EQU $780
|
QNdx0 EQU $780
|
Line 287... |
Line 305... |
CharOutVec EQU $800
|
CharOutVec EQU $800
|
CharInVec EQU $804
|
CharInVec EQU $804
|
CmdPromptJI EQU $808
|
CmdPromptJI EQU $808
|
MonErrVec EQU $80C
|
MonErrVec EQU $80C
|
BreakpointFlag EQU $810
|
BreakpointFlag EQU $810
|
NumSetBreakpoints EQU $811
|
NumSetBreakpoints EQU $811 ; to 812
|
Breakpoints EQU $820 ; to $82F
|
Breakpoints EQU $820 ; to $82F
|
BreakpointBytes EQU $830 ; to $83F
|
BreakpointBytes EQU $830 ; to $83F
|
mon_vectb EQU $880
|
mon_vectb EQU $880
|
|
|
; Register save area for monitor
|
; Register save area for monitor
|
Line 318... |
Line 336... |
00FFD0AC 012 nop
|
00FFD0AC 012 nop
|
00FFD0AD 012 nop
|
00FFD0AD 012 nop
|
00FFD0AE 012 nop
|
00FFD0AE 012 nop
|
XBLANK
|
XBLANK
|
00FFD0AF 0C6020 ldb #' '
|
00FFD0AF 0C6020 ldb #' '
|
00FFD0B1 017001E2D lbsr OUTCH
|
00FFD0B1 017002115 lbsr OUTCH
|
00FFD0B4 039 rts
|
00FFD0B4 039 rts
|
|
|
org $FFD0D0
|
org $FFD0D0
|
00FFD0D0 012 nop
|
00FFD0D0 012 nop
|
00FFD0D1 012 nop
|
00FFD0D1 012 nop
|
CRLF
|
CRLF
|
CRLF1:
|
CRLF1:
|
00FFD0D2 0C600D ldb #CR
|
00FFD0D2 0C600D ldb #CR
|
00FFD0D4 017001E0A lbsr OUTCH
|
00FFD0D4 0170020F2 lbsr OUTCH
|
00FFD0D7 0C600A ldb #LF
|
00FFD0D7 0C600A ldb #LF
|
00FFD0D9 017001E05 lbsr OUTCH
|
00FFD0D9 0170020ED lbsr OUTCH
|
00FFD0DC 039 rts
|
00FFD0DC 039 rts
|
|
|
org $FFD0F0
|
org $FFD0F0
|
00FFD0F0 012 nop
|
00FFD0F0 012 nop
|
00FFD0F1 020FDF bra CRLF1
|
00FFD0F1 020FDF bra CRLF1
|
Line 343... |
Line 361... |
00FFD1DC 06E90F000804 jmp [CharInVec]
|
00FFD1DC 06E90F000804 jmp [CharInVec]
|
|
|
org $FFD2C0
|
org $FFD2C0
|
00FFD2C0 012 nop
|
00FFD2C0 012 nop
|
LETTER
|
LETTER
|
00FFD2C1 017001C1D lbsr OUTCH
|
00FFD2C1 017001F05 lbsr OUTCH
|
00FFD2C4 039 rts
|
00FFD2C4 039 rts
|
|
|
org $FFD2CC
|
org $FFD2CC
|
00FFD2CC 012 nop
|
00FFD2CC 012 nop
|
00FFD2CD 012 nop
|
00FFD2CD 012 nop
|
HEX2
|
HEX2
|
00FFD2CE 017001166 lbsr DispByteAsHex
|
00FFD2CE 017001169 lbsr DispByteAsHex
|
00FFD2D1 039 rts
|
00FFD2D1 039 rts
|
HEX4
|
HEX4
|
00FFD2D2 017001159 lbsr DispWordAsHex
|
00FFD2D2 01700115C lbsr DispWordAsHex
|
00FFD2D5 039 rts
|
00FFD2D5 039 rts
|
|
|
org $FFD300
|
org $FFD300
|
ClearScreenJmp
|
ClearScreenJmp
|
00FFD300 016000F36 lbra ClearScreen
|
00FFD300 016000F39 lbra ClearScreen
|
org $FFD308
|
org $FFD308
|
HomeCursorJmp
|
HomeCursorJmp
|
00FFD308 016000FA5 lbra HomeCursor
|
00FFD308 016000FA8 lbra HomeCursor
|
|
|
org $FFD400
|
org $FFD400
|
|
|
; Local RAM test routine
|
; Local RAM test routine
|
; Checkerboard testing.
|
; Checkerboard testing.
|
Line 406... |
Line 424... |
ramerr1:
|
ramerr1:
|
00FFD445 06EC04 jmp ,u
|
00FFD445 06EC04 jmp ,u
|
|
|
|
|
org $FFE000
|
org $FFE000
|
00FFE000 FFF039 FDB Monitor
|
00FFE000 FFF35C FDB Monitor
|
00FFE002 FFE022 FDB DumRts ; NEXTCMD
|
00FFE002 FFE022 FDB DumRts ; NEXTCMD
|
00FFE004 FFEEA9 FDB INCH
|
00FFE004 FFF191 FDB INCH
|
00FFE006 FFEEC7 FDB INCHE
|
00FFE006 FFF1AF FDB INCHE
|
00FFE008 FFEECB FDB INCHEK
|
00FFE008 FFF1B3 FDB INCHEK
|
00FFE00A FFEEE1 FDB OUTCH
|
00FFE00A FFF1C9 FDB OUTCH
|
00FFE00C FFE41B FDB PDATA
|
00FFE00C FFE41E FDB PDATA
|
00FFE00E FFE40E FDB PCRLF
|
00FFE00E FFE411 FDB PCRLF
|
00FFE010 FFE40A FDB PSTRNG
|
00FFE010 FFE40D FDB PSTRNG
|
00FFE012 FFE022 FDB DumRts ; LRA
|
00FFE012 FFE022 FDB DumRts ; LRA
|
00FFE014 FFE022 FDB DumRts
|
00FFE014 FFE022 FDB DumRts
|
00FFE016 FFE022 FDB DumRts
|
00FFE016 FFE022 FDB DumRts
|
00FFE018 FFE022 FDB DumRts
|
00FFE018 FFE022 FDB DumRts
|
00FFE01A FFE022 FDB DumRts ; VINIZ
|
00FFE01A FFE022 FDB DumRts ; VINIZ
|
00FFE01C FFE319 FDB DisplayChar ; VOUTCH
|
00FFE01C FFE31C FDB DisplayChar ; VOUTCH
|
00FFE01E FFE022 FDB DumRts ; ACINIZ
|
00FFE01E FFE022 FDB DumRts ; ACINIZ
|
00FFE020 FFE022 FDB DumRts ; AOUTCH
|
00FFE020 FFE022 FDB DumRts ; AOUTCH
|
|
|
DumRts:
|
DumRts:
|
00FFE022 039 rts
|
00FFE022 039 rts
|
Line 453... |
Line 471... |
; bsr romToRam
|
; bsr romToRam
|
; ldd #st7 & $FFFF
|
; ldd #st7 & $FFFF
|
; tfr d,x
|
; tfr d,x
|
; jmp ,x ; jump to the BIOS now in local RAM
|
; jmp ,x ; jump to the BIOS now in local RAM
|
st7:
|
st7:
|
00FFE046 08D16D bsr Delay3s ; give some time for devices to reset
|
00FFE046 08D170 bsr Delay3s ; give some time for devices to reset
|
00FFE048 07F000810 clr BreakpointFlag
|
00FFE048 07F000810 clr BreakpointFlag
|
00FFE04B 07F000811 clr NumSetBreakpoints
|
00FFE04B 07F000811 clr NumSetBreakpoints
|
00FFE04E 0860AA lda #$AA
|
00FFE04E 0860AA lda #$AA
|
00FFE050 0150B7FFFE60001 sta LEDS
|
00FFE050 0150B7FFFE60001 sta LEDS
|
00FFE055 0150B6FFFFFFFE0 lda COREID
|
00FFE055 0150B6FFFFFFFE0 lda COREID
|
Line 478... |
Line 496... |
00FFE077 0B7FFC001 sta IOFocusList+FIRST_CORE
|
00FFE077 0B7FFC001 sta IOFocusList+FIRST_CORE
|
|
|
00FFE07A 0860CE lda #$0CE
|
00FFE07A 0860CE lda #$0CE
|
00FFE07C 097113 sta ScreenColor
|
00FFE07C 097113 sta ScreenColor
|
00FFE07E 097112 sta CharColor
|
00FFE07E 097112 sta CharColor
|
00FFE080 08D1B7 bsr ClearScreen
|
00FFE080 08D1BA bsr ClearScreen
|
00FFE082 0CCFFE319 ldd #DisplayChar
|
00FFE082 0CCFFE31C ldd #DisplayChar
|
00FFE085 0FD000800 std CharOutVec
|
00FFE085 0FD000800 std CharOutVec
|
00FFE088 0CCFFEC64 ldd #SerialPeekCharDirect
|
00FFE088 0CCFFEC73 ldd #SerialPeekCharDirect
|
00FFE08B 0FD000804 std CharInVec
|
00FFE08B 0FD000804 std CharInVec
|
; swi
|
; swi
|
; fcb MF_OSCALL
|
; fcb MF_OSCALL
|
; fcb 24 ; request IO focus
|
; fcb 24 ; request IO focus
|
00FFE08E 0150F6FFFFFFFE0 ldb COREID
|
00FFE08E 0150F6FFFFFFFE0 ldb COREID
|
00FFE093 0C1001 cmpb #FIRST_CORE
|
00FFE093 0C1001 cmpb #FIRST_CORE
|
00FFE095 027011 beq init
|
00FFE095 027011 beq init
|
00FFE097 0C1020 cmpb #$20 ; CmodA709 core?
|
00FFE097 0C1020 cmpb #$20 ; CmodA709 core?
|
00FFE099 02705D beq init2
|
00FFE099 027060 beq init2
|
00FFE09B 02006D bra skip_init
|
00FFE09B 020070 bra skip_init
|
00FFE09D 0200B4 bra multi_sieve
|
00FFE09D 0200B7 bra multi_sieve
|
st3:
|
st3:
|
00FFE09F 0860FF lda #$FF
|
00FFE09F 0860FF lda #$FF
|
00FFE0A1 0150B7FFFE60001 sta LEDS
|
00FFE0A1 0150B7FFFE60001 sta LEDS
|
00FFE0A6 020FF7 bra st3
|
00FFE0A6 020FF7 bra st3
|
|
|
; initialize interrupt controller
|
; initialize interrupt controller
|
; first, zero out all the vectors
|
; first, zero out all the vectors
|
init:
|
init:
|
00FFE0A8 017000449 lbsr rtc_read ; get clock values
|
00FFE0A8 017000479 lbsr rtc_read ; get clock values
|
00FFE0AB 08E000127 ldx #kbdHeadRcv
|
00FFE0AB 08E000127 ldx #kbdHeadRcv
|
00FFE0AE 0C6020 ldb #32 ; number of bytes to zero out
|
00FFE0AE 0C6020 ldb #32 ; number of bytes to zero out
|
init1:
|
init1:
|
00FFE0B0 06F800 clr ,x+
|
00FFE0B0 06F800 clr ,x+
|
00FFE0B2 05A decb
|
00FFE0B2 05A decb
|
00FFE0B3 026FFB bne init1
|
00FFE0B3 026FFB bne init1
|
|
00FFE0B5 08E000080 ldx #128 ; register to start at
|
st1:
|
st1:
|
00FFE0B5 06F809E3F000 clr PIC,x ; cause code
|
00FFE0B8 06F809E3F000 clr PIC,x ; cause code
|
00FFE0B9 0A7809E3F001 sta PIC+1,x
|
00FFE0BC 0A7809E3F001 sta PIC+1,x
|
00FFE0BD 0E7809E3F002 stb PIC+2,x
|
00FFE0C0 0E7809E3F002 stb PIC+2,x
|
00FFE0C1 030004 leax 4,x
|
00FFE0C4 030004 leax 4,x
|
00FFE0C3 08C000100 cmpx #256
|
00FFE0C6 08C000100 cmpx #256 ; max reg
|
00FFE0C6 025FED blo st1
|
00FFE0C9 025FED blo st1
|
00FFE0C8 086081 lda #$81 ; make irq edge sensitive
|
00FFE0CB 0860C1 lda #$C1 ; make irq edge sensitive (bit 7), enable interupt (bit 6), irq (bit 0)
|
00FFE0CA 0150B7FFFE3F0FD sta PIC+$FD
|
00FFE0CD 0150B7FFFE3F0FD sta PIC+$FD
|
00FFE0CF 08601F lda #31 ; enable timer interrupt
|
00FFE0D2 086041 lda #$41 ; level sensitive, enabled, irq
|
00FFE0D1 0150B7FFFE3F009 sta PIC+9
|
00FFE0D4 0150B7FFFE3F0D1 sta PIC+$D1 ; serial irq is #20
|
00FFE0D6 086040 lda #COLS
|
00FFE0D9 086040 lda #COLS
|
00FFE0D8 0150B7FFFE07F00 sta TEXTREG+TEXT_COLS
|
00FFE0DB 0150B7FFFE07F00 sta TEXTREG+TEXT_COLS
|
00FFE0DD 086020 lda #ROWS
|
00FFE0E0 086020 lda #ROWS
|
00FFE0DF 0150B7FFFE07F01 sta TEXTREG+TEXT_ROWS
|
00FFE0E2 0150B7FFFE07F01 sta TEXTREG+TEXT_ROWS
|
00FFE0E4 08D153 bsr ClearScreen
|
00FFE0E7 08D153 bsr ClearScreen
|
00FFE0E6 08D1C8 bsr HomeCursor
|
00FFE0E9 08D1C8 bsr HomeCursor
|
00FFE0E8 08E000000 ldx #0
|
00FFE0EB 08E000000 ldx #0
|
00FFE0EB 0CC000000 ldd #0
|
00FFE0EE 0CC000000 ldd #0
|
00FFE0EE 017000DFA lbsr ShowSprites
|
00FFE0F1 0170010DF lbsr ShowSprites
|
00FFE0F1 0170008CC lbsr KeybdInit
|
00FFE0F4 0170008C9 lbsr KeybdInit
|
00FFE0F4 0DC124 ldd KeybdID
|
00FFE0F7 0DC124 ldd KeybdID
|
00FFE0F6 08D336 bsr DispWordAsHex
|
00FFE0F9 08D336 bsr DispWordAsHex
|
init2:
|
init2:
|
00FFE0F8 01700036A lbsr TimerInit
|
00FFE0FB 01700036A lbsr TimerInit
|
00FFE0FB 017000AF1 lbsr InitSerial
|
00FFE0FE 017000AEE lbsr InitSerial
|
00FFE0FE 08E000080 ldx #128
|
00FFE101 08E000080 ldx #128
|
00FFE101 086001 lda #1 ; set irq(bit0), clear firq (bit1), disable int (bit 6), clear edge sense(bit 7)
|
00FFE104 086001 lda #1 ; set irq(bit0), clear firq (bit1), disable int (bit 6), clear edge sense(bit 7)
|
00FFE103 0C6001 ldb #FIRST_CORE ; serving core id
|
00FFE106 0C6001 ldb #FIRST_CORE ; serving core id
|
; lda #4 ; make the timer interrupt edge sensitive
|
; lda #4 ; make the timer interrupt edge sensitive
|
; sta PIC+4 ; reg #4 is the edge sensitivity setting
|
; sta PIC+4 ; reg #4 is the edge sensitivity setting
|
; sta PIC ; reg #0 is interrupt enable
|
; sta PIC ; reg #0 is interrupt enable
|
00FFE105 0C6001 ldb #1
|
00FFE108 0C6001 ldb #1
|
00FFE107 0F7EF1000 stb OUTSEMA+SEMAABS ; set semaphore to 1 available slot
|
00FFE10A 0F7EF1000 stb OUTSEMA+SEMAABS ; set semaphore to 1 available slot
|
skip_init:
|
skip_init:
|
00FFE10A 01C0EF andcc #$EF ; unmask irq
|
00FFE10D 01C0EF andcc #$EF ; unmask irq
|
00FFE10C 086005 lda #5
|
00FFE10F 086005 lda #5
|
00FFE10E 0150B7FFFE60001 sta LEDS
|
00FFE111 0150B7FFFE60001 sta LEDS
|
00FFE113 0CCFFE11C ldd #msgStartup
|
00FFE116 0CCFFE11F ldd #msgStartup
|
00FFE116 08D2C2 bsr DisplayString
|
00FFE119 08D2C2 bsr DisplayString
|
st10:
|
st10:
|
00FFE118 03F swi
|
00FFE11B 03F swi
|
00FFE119 000 fcb MF_Monitor
|
00FFE11C 000 fcb MF_Monitor
|
00FFE11A 020FFC bra st10
|
00FFE11D 020FFC bra st10
|
|
|
msgStartup
|
msgStartup
|
00FFE11C 072066036038030039020 fcb "rf6809 12-bit System Starting.",CR,LF,0
|
00FFE11F 072066036038030039020 fcb "rf6809 12-bit System Starting.",CR,LF,0
|
00FFE123 03103202D062069074020
|
00FFE126 03103202D062069074020
|
00FFE12A 05307907307406506D020
|
00FFE12D 05307907307406506D020
|
00FFE131 05307406107207406906E
|
00FFE134 05307406107207406906E
|
00FFE138 06702E00D00A000
|
00FFE13B 06702E00D00A000
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; The checkpoint register must be cleared within 1 second or a NMI interrupt
|
; The checkpoint register must be cleared within 1 second or a NMI interrupt
|
; will occur. checkpoint should be called with a JSR so that the global ROM
|
; will occur. checkpoint should be called with a JSR so that the global ROM
|
; routine is called.
|
; routine is called.
|
Line 570... |
Line 589... |
; Modifies:
|
; Modifies:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
checkpoint:
|
checkpoint:
|
00FFE13D 01507FFFFFFFFE1 clr $FFFFFFFE1 ; writing any value will do
|
00FFE140 01507FFFFFFFFE1 clr $FFFFFFFE1 ; writing any value will do
|
00FFE142 039 rts
|
00FFE145 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Copy the system ROM to local RAM
|
; Copy the system ROM to local RAM
|
; Running the code from local RAM is probably an order of magnitude faster
|
; Running the code from local RAM is probably an order of magnitude faster
|
; then running from the global ROM. It also reduces the network traffic to
|
; then running from the global ROM. It also reduces the network traffic to
|
Line 584... |
Line 603... |
; Modifies:
|
; Modifies:
|
; d,x,y
|
; d,x,y
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
romToRam:
|
romToRam:
|
00FFE143 08EFFC000 ldx #$FFC000
|
00FFE146 08EFFC000 ldx #$FFC000
|
00FFE146 18E00C000 ldy #$00C000
|
00FFE149 18E00C000 ldy #$00C000
|
romToRam1:
|
romToRam1:
|
00FFE149 0EC801 ldd ,x++
|
00FFE14C 0EC801 ldd ,x++
|
00FFE14B 0EDA01 std ,y++
|
00FFE14E 0EDA01 std ,y++
|
00FFE14D 08C000000 cmpx #0
|
00FFE150 08C000000 cmpx #0
|
00FFE150 026FF7 bne romToRam1
|
00FFE153 026FF7 bne romToRam1
|
00FFE152 039 rts
|
00FFE155 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Multi-core sieve program.
|
; Multi-core sieve program.
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
; First fill screen chars with 'P' indicating prime positions
|
; First fill screen chars with 'P' indicating prime positions
|
; Each core is responsible for the Nth position where N is the
|
; Each core is responsible for the Nth position where N is the
|
; core number minus two.
|
; core number minus two.
|
;
|
;
|
multi_sieve:
|
multi_sieve:
|
00FFE153 086050 lda #'P' ; indicate prime
|
00FFE156 086050 lda #'P' ; indicate prime
|
00FFE155 0150F6FFFFFFFE0 ldb COREID ; find out which core we are
|
00FFE158 0150F6FFFFFFFE0 ldb COREID ; find out which core we are
|
00FFE15A 0C0001 subb #FIRST_CORE
|
00FFE15D 0C0001 subb #FIRST_CORE
|
00FFE15C 08E000000 ldx #0 ; start at first char of screen
|
00FFE15F 08E000000 ldx #0 ; start at first char of screen
|
00FFE15F 03A abx
|
00FFE162 03A abx
|
multi_sieve3:
|
multi_sieve3:
|
00FFE160 0A7809E00000 sta TEXTSCR,x ; store 'P'
|
00FFE163 0A7809E00000 sta TEXTSCR,x ; store 'P'
|
00FFE164 030008 leax 8,x ; advance to next position
|
00FFE167 030008 leax 8,x ; advance to next position
|
00FFE166 08C000FFF cmpx #4095
|
00FFE169 08C000FFF cmpx #4095
|
00FFE169 025FF5 blo multi_sieve3
|
00FFE16C 025FF5 blo multi_sieve3
|
00FFE16B 0BDFFE13D jsr checkpoint
|
00FFE16E 0BDFFE140 jsr checkpoint
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFE16E 0CB002 addb #2 ; start sieve at 2 (core id)
|
00FFE171 0CB002 addb #2 ; start sieve at 2 (core id)
|
00FFE170 08604E lda #'N' ; flag position value of 'N' for non-prime
|
00FFE173 08604E lda #'N' ; flag position value of 'N' for non-prime
|
multi_sieve2:
|
multi_sieve2:
|
00FFE172 08E000000 ldx #0
|
00FFE175 08E000000 ldx #0
|
00FFE175 03A abx ; skip the first position - might be prime
|
00FFE178 03A abx ; skip the first position - might be prime
|
multi_sieve1:
|
multi_sieve1:
|
00FFE176 03A abx ; increment
|
00FFE179 03A abx ; increment
|
00FFE177 0A7809E00000 sta TEXTSCR,x
|
00FFE17A 0A7809E00000 sta TEXTSCR,x
|
00FFE17B 08C000FFF cmpx #4095
|
00FFE17E 08C000FFF cmpx #4095
|
00FFE17E 025FF6 blo multi_sieve1
|
00FFE181 025FF6 blo multi_sieve1
|
00FFE180 0BDFFE13D jsr checkpoint
|
00FFE183 0BDFFE140 jsr checkpoint
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFE183 0CB008 addb #8 ; number of cores working on it
|
00FFE186 0CB008 addb #8 ; number of cores working on it
|
00FFE185 0C1FF0 cmpb #4080
|
00FFE188 0C1FF0 cmpb #4080
|
00FFE187 025FE9 blo multi_sieve2
|
00FFE18A 025FE9 blo multi_sieve2
|
multi_sieve4: ; hang machine
|
multi_sieve4: ; hang machine
|
00FFE189 013 sync
|
00FFE18C 013 sync
|
00FFE18A 016000EAC lbra Monitor
|
00FFE18D 0160011CC lbra Monitor
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Single core sieve.
|
; Single core sieve.
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
sieve:
|
sieve:
|
00FFE18D 086050 lda #'P' ; indicate prime
|
00FFE190 086050 lda #'P' ; indicate prime
|
00FFE18F 08E000000 ldx #0 ; start at first char of screen
|
00FFE192 08E000000 ldx #0 ; start at first char of screen
|
sieve3:
|
sieve3:
|
00FFE192 0A7809E00000 sta TEXTSCR,x ; store 'P'
|
00FFE195 0A7809E00000 sta TEXTSCR,x ; store 'P'
|
00FFE196 030001 inx ; advance to next position
|
00FFE199 030001 inx ; advance to next position
|
00FFE198 08C000FFF cmpx #4095
|
00FFE19B 08C000FFF cmpx #4095
|
00FFE19B 025FF5 blo sieve3
|
00FFE19E 025FF5 blo sieve3
|
00FFE19D 0C6002 ldb #2 ; start sieve at 2
|
00FFE1A0 0C6002 ldb #2 ; start sieve at 2
|
00FFE19F 08604E lda #'N' ; flag position value of 'N' for non-prime
|
00FFE1A2 08604E lda #'N' ; flag position value of 'N' for non-prime
|
sieve2:
|
sieve2:
|
00FFE1A1 08E000000 ldx #0
|
00FFE1A4 08E000000 ldx #0
|
00FFE1A4 03A abx ; skip the first position - might be prime
|
00FFE1A7 03A abx ; skip the first position - might be prime
|
sieve1:
|
sieve1:
|
00FFE1A5 03A abx ; increment
|
00FFE1A8 03A abx ; increment
|
00FFE1A6 0A7809E00000 sta TEXTSCR,x
|
00FFE1A9 0A7809E00000 sta TEXTSCR,x
|
00FFE1AA 08C000FFF cmpx #4095
|
00FFE1AD 08C000FFF cmpx #4095
|
00FFE1AD 025FC7 blo multi_sieve1
|
00FFE1B0 025FC7 blo multi_sieve1
|
00FFE1AF 05C incb ; number of cores working on it
|
00FFE1B2 05C incb ; number of cores working on it
|
00FFE1B0 0C1FF0 cmpb #4080
|
00FFE1B3 0C1FF0 cmpb #4080
|
00FFE1B2 025FED blo sieve2
|
00FFE1B5 025FED blo sieve2
|
sieve4: ; hang machine
|
sieve4: ; hang machine
|
00FFE1B4 039 rts
|
00FFE1B7 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Three second delay for user convenience and to allow some devices time to
|
; Three second delay for user convenience and to allow some devices time to
|
; reset.
|
; reset.
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
Delay3s:
|
Delay3s:
|
00FFE1B5 0CC895440 ldd #9000000
|
00FFE1B8 0CC895440 ldd #9000000
|
dly3s1:
|
dly3s1:
|
00FFE1B8 0C10FF cmpb #$FF
|
00FFE1BB 0C10FF cmpb #$FF
|
00FFE1BA 026000 bne dly3s2
|
00FFE1BD 026000 bne dly3s2
|
dly3s2:
|
dly3s2:
|
00FFE1BC 0150B7FFFE60001 sta LEDS
|
00FFE1BF 0150B7FFFE60001 sta LEDS
|
00FFE1C1 083000001 subd #1
|
00FFE1C4 083000001 subd #1
|
00FFE1C4 026FF2 bne dly3s1
|
00FFE1C7 026FF2 bne dly3s1
|
00FFE1C6 039 rts
|
00FFE1C9 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
ShiftLeft5:
|
ShiftLeft5:
|
00FFE1C7 058 aslb
|
00FFE1CA 058 aslb
|
00FFE1C8 049 rola
|
00FFE1CB 049 rola
|
00FFE1C9 058 aslb
|
00FFE1CC 058 aslb
|
00FFE1CA 049 rola
|
00FFE1CD 049 rola
|
00FFE1CB 058 aslb
|
00FFE1CE 058 aslb
|
00FFE1CC 049 rola
|
00FFE1CF 049 rola
|
00FFE1CD 058 aslb
|
00FFE1D0 058 aslb
|
00FFE1CE 049 rola
|
00FFE1D1 049 rola
|
00FFE1CF 058 aslb
|
00FFE1D2 058 aslb
|
00FFE1D0 049 rola
|
00FFE1D3 049 rola
|
00FFE1D1 039 rts
|
00FFE1D4 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Parameters:
|
; Parameters:
|
; b = core id of core to copy
|
; b = core id of core to copy
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
CopyVirtualScreenToScreen:
|
CopyVirtualScreenToScreen:
|
00FFE1D2 034076 pshs d,x,y,u
|
00FFE1D5 034076 pshs d,x,y,u
|
; Compute virtual screen location for core passed in accb.
|
; Compute virtual screen location for core passed in accb.
|
00FFE1D4 01F098 tfr b,a
|
00FFE1D7 01F098 tfr b,a
|
00FFE1D6 048 asla
|
|
00FFE1D7 048 asla
|
|
00FFE1D8 048 asla
|
|
00FFE1D9 048 asla
|
00FFE1D9 048 asla
|
00FFE1DA 08AC00 ora #$C00
|
00FFE1DA 048 asla
|
00FFE1DC 05F clrb
|
00FFE1DB 048 asla
|
00FFE1DD 01F001 tfr d,x
|
00FFE1DC 048 asla
|
00FFE1DF 034006 pshs d
|
00FFE1DD 08AC00 ora #$C00
|
00FFE1E1 18EE00000 ldy #TEXTSCR
|
00FFE1DF 05F clrb
|
00FFE1E4 0CE000400 ldu #COLS*ROWS/2
|
00FFE1E0 01F001 tfr d,x
|
|
00FFE1E2 034006 pshs d
|
|
00FFE1E4 18EE00000 ldy #TEXTSCR
|
|
00FFE1E7 0CE000400 ldu #COLS*ROWS/2
|
cv2s1:
|
cv2s1:
|
00FFE1E7 0EC801 ldd ,x++
|
00FFE1EA 0EC801 ldd ,x++
|
00FFE1E9 0EDA01 std ,y++
|
00FFE1EC 0EDA01 std ,y++
|
00FFE1EB 0335FF leau -1,u
|
00FFE1EE 0335FF leau -1,u
|
00FFE1ED 283000000 cmpu #0
|
00FFE1F0 283000000 cmpu #0
|
00FFE1F0 026FF5 bne cv2s1
|
00FFE1F3 026FF5 bne cv2s1
|
; reset the cursor position in the text controller
|
; reset the cursor position in the text controller
|
00FFE1F2 035010 puls x
|
00FFE1F5 035010 puls x
|
00FFE1F4 0E6808110 ldb CursorRow,x
|
00FFE1F7 0E6808110 ldb CursorRow,x
|
00FFE1F7 086040 lda #COLS
|
00FFE1FA 086040 lda #COLS
|
00FFE1F9 03D mul
|
00FFE1FC 03D mul
|
00FFE1FA 01F002 tfr d,y
|
00FFE1FD 01F002 tfr d,y
|
00FFE1FC 0E6808111 ldb CursorCol,x
|
00FFE1FF 0E6808111 ldb CursorCol,x
|
00FFE1FF 01F021 tfr y,x
|
00FFE202 01F021 tfr y,x
|
00FFE201 03A abx
|
00FFE204 03A abx
|
00FFE202 0150BFFFFE07F22 stx TEXTREG+TEXT_CURPOS
|
00FFE205 0150BFFFFE07F22 stx TEXTREG+TEXT_CURPOS
|
00FFE207 0350F6 puls d,x,y,u,pc
|
00FFE20A 0350F6 puls d,x,y,u,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
CopyScreenToVirtualScreen:
|
CopyScreenToVirtualScreen:
|
00FFE209 034076 pshs d,x,y,u
|
00FFE20C 034076 pshs d,x,y,u
|
00FFE20B 08D08D bsr GetScreenLocation
|
00FFE20E 08D08D bsr GetScreenLocation
|
00FFE20D 01F002 tfr d,y
|
00FFE210 01F002 tfr d,y
|
00FFE20F 08EE00000 ldx #TEXTSCR
|
00FFE212 08EE00000 ldx #TEXTSCR
|
00FFE212 0CE000400 ldu #COLS*ROWS/2
|
00FFE215 0CE000400 ldu #COLS*ROWS/2
|
cs2v1:
|
cs2v1:
|
00FFE215 0EC801 ldd ,x++
|
00FFE218 0EC801 ldd ,x++
|
00FFE217 0EDA01 std ,y++
|
00FFE21A 0EDA01 std ,y++
|
00FFE219 0335FF leau -1,u
|
00FFE21C 0335FF leau -1,u
|
00FFE21B 283000000 cmpu #0
|
00FFE21E 283000000 cmpu #0
|
00FFE21E 026FF5 bne cs2v1
|
00FFE221 026FF5 bne cs2v1
|
00FFE220 0350F6 puls d,x,y,u,pc
|
00FFE223 0350F6 puls d,x,y,u,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
00FFE222 054045058054053043052 fcb "TEXTSCR "
|
00FFE225 054045058054053043052 fcb "TEXTSCR "
|
00FFE229 020
|
00FFE22C 020
|
00FFE22A FFE234 fcw TextOpen
|
00FFE22D FFE237 fcw TextOpen
|
00FFE22C FFE235 fcw TextClose
|
00FFE22F FFE238 fcw TextClose
|
00FFE22E FFE236 fcw TextRead
|
00FFE231 FFE239 fcw TextRead
|
00FFE230 FFE237 fcw TextWrite
|
00FFE233 FFE23A fcw TextWrite
|
00FFE232 FFE238 fcw TextSeek
|
00FFE235 FFE23B fcw TextSeek
|
|
|
TextOpen:
|
TextOpen:
|
00FFE234 039 rts
|
00FFE237 039 rts
|
TextClose:
|
TextClose:
|
00FFE235 039 rts
|
00FFE238 039 rts
|
TextRead:
|
TextRead:
|
00FFE236 039 rts
|
00FFE239 039 rts
|
TextWrite:
|
TextWrite:
|
00FFE237 039 rts
|
00FFE23A 039 rts
|
TextSeek:
|
TextSeek:
|
00FFE238 039 rts
|
00FFE23B 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Clear the screen and the screen color memory
|
; Clear the screen and the screen color memory
|
; We clear the screen to give a visual indication that the system
|
; We clear the screen to give a visual indication that the system
|
; is working at all.
|
; is working at all.
|
Line 777... |
Line 796... |
; Modifies:
|
; Modifies:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
ClearScreen:
|
ClearScreen:
|
00FFE239 034076 pshs d,x,y,u
|
00FFE23C 034076 pshs d,x,y,u
|
00FFE23B 08E000800 ldx #COLS*ROWS
|
00FFE23E 08E000800 ldx #COLS*ROWS
|
00FFE23E 01F013 tfr x,u
|
00FFE241 01F013 tfr x,u
|
00FFE240 08D058 bsr GetScreenLocation
|
00FFE243 08D058 bsr GetScreenLocation
|
00FFE242 01F002 tfr d,y
|
00FFE245 01F002 tfr d,y
|
00FFE244 0C6020 ldb #' ' ; space char
|
00FFE247 0C6020 ldb #' ' ; space char
|
cs1:
|
cs1:
|
00FFE246 0E7A00 stb ,y+ ; set text to space
|
00FFE249 0E7A00 stb ,y+ ; set text to space
|
00FFE248 0301FF leax -1,x ; decrement x
|
00FFE24B 0301FF leax -1,x ; decrement x
|
00FFE24A 026FFA bne cs1
|
00FFE24D 026FFA bne cs1
|
00FFE24C 0150F6FFFFFFFE0 ldb COREID ; update colors only if we have focus
|
00FFE24F 0150F6FFFFFFFE0 ldb COREID ; update colors only if we have focus
|
00FFE251 0F1FFC010 cmpb IOFocusID
|
00FFE254 0F1FFC010 cmpb IOFocusID
|
00FFE254 02000D bra cs3
|
00FFE257 02000D bra cs3
|
00FFE256 18EE02000 ldy #TEXTSCR+$2000
|
00FFE259 18EE02000 ldy #TEXTSCR+$2000
|
; lda CharColor
|
; lda CharColor
|
00FFE259 0860CE lda #$0CE
|
00FFE25C 0860CE lda #$0CE
|
00FFE25B 01F031 tfr u,x ; get back count
|
00FFE25E 01F031 tfr u,x ; get back count
|
cs2:
|
cs2:
|
00FFE25D 0A7A00 sta ,y+
|
00FFE260 0A7A00 sta ,y+
|
00FFE25F 0301FF dex ; decrement x
|
00FFE262 0301FF dex ; decrement x
|
00FFE261 026FFA bne cs2
|
00FFE264 026FFA bne cs2
|
cs3:
|
cs3:
|
00FFE263 0350F6 puls d,x,y,u,pc
|
00FFE266 0350F6 puls d,x,y,u,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Scroll text on the screen upwards
|
; Scroll text on the screen upwards
|
;
|
;
|
; Modifies:
|
; Modifies:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
ScrollUp:
|
ScrollUp:
|
00FFE265 034076 pshs d,x,y,u
|
00FFE268 034076 pshs d,x,y,u
|
00FFE267 18E0003FF ldy #(COLS*ROWS-1)/2 ; y = num chars/2 to move
|
00FFE26A 18E0003FF ldy #(COLS*ROWS-1)/2 ; y = num chars/2 to move
|
00FFE26A 08D02E bsr GetScreenLocation
|
00FFE26D 08D02E bsr GetScreenLocation
|
00FFE26C 01F001 tfr d,x
|
00FFE26F 01F001 tfr d,x
|
00FFE26E 01F003 tfr d,u
|
00FFE271 01F003 tfr d,u
|
00FFE270 030040 leax COLS,x ; x = index to source row
|
00FFE273 030040 leax COLS,x ; x = index to source row
|
scrup1:
|
scrup1:
|
00FFE272 0EC801 ldd ,x++ ; move 2 characters
|
00FFE275 0EC801 ldd ,x++ ; move 2 characters
|
00FFE274 0EDC01 std ,u++
|
00FFE277 0EDC01 std ,u++
|
00FFE276 0313FF dey
|
00FFE279 0313FF dey
|
00FFE278 026FF8 bne scrup1
|
00FFE27B 026FF8 bne scrup1
|
00FFE27A 08601F lda #ROWS-1
|
00FFE27D 08601F lda #ROWS-1
|
00FFE27C 08D002 bsr BlankLine
|
00FFE27F 08D002 bsr BlankLine
|
00FFE27E 0350F6 puls d,x,y,u,pc
|
00FFE281 0350F6 puls d,x,y,u,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Blank out a line on the display
|
; Blank out a line on the display
|
;
|
;
|
; Modifies:
|
; Modifies:
|
Line 834... |
Line 853... |
; Parameters:
|
; Parameters:
|
; acca = line number to blank
|
; acca = line number to blank
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
BlankLine:
|
BlankLine:
|
00FFE280 034016 pshs d,x
|
00FFE283 034016 pshs d,x
|
00FFE282 034002 pshs a
|
00FFE285 034002 pshs a
|
00FFE284 08D014 bsr GetScreenLocation
|
00FFE287 08D014 bsr GetScreenLocation
|
00FFE286 01F001 tfr d,x
|
00FFE289 01F001 tfr d,x
|
00FFE288 035002 puls a
|
00FFE28B 035002 puls a
|
00FFE28A 0C6040 ldb #COLS ; b = # chars to blank out from video controller
|
00FFE28D 0C6040 ldb #COLS ; b = # chars to blank out from video controller
|
00FFE28C 03D mul ; d = screen index (row# * #cols)
|
00FFE28F 03D mul ; d = screen index (row# * #cols)
|
00FFE28D 03080B leax d,x
|
00FFE290 03080B leax d,x
|
00FFE28F 086020 lda #' '
|
00FFE292 086020 lda #' '
|
00FFE291 0C6040 ldb #COLS ; b = # chars to blank out from video controller
|
00FFE294 0C6040 ldb #COLS ; b = # chars to blank out from video controller
|
blnkln1:
|
blnkln1:
|
00FFE293 0A7800 sta ,x+
|
00FFE296 0A7800 sta ,x+
|
00FFE295 05A decb
|
00FFE298 05A decb
|
00FFE296 026FFB bne blnkln1
|
00FFE299 026FFB bne blnkln1
|
00FFE298 035096 puls d,x,pc
|
00FFE29B 035096 puls d,x,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Get the location of the screen memory. The location
|
; Get the location of the screen memory. The location
|
; depends on whether or not the task has the output focus.
|
; depends on whether or not the task has the output focus.
|
;
|
;
|
Line 861... |
Line 880... |
; Retuns:
|
; Retuns:
|
; d = screen location
|
; d = screen location
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
GetScreenLocation:
|
GetScreenLocation:
|
00FFE29A 0150B6FFFFFFFE0 lda COREID ; which core are we?
|
00FFE29D 0150B6FFFFFFFE0 lda COREID ; which core are we?
|
00FFE29F 0B1FFC010 cmpa IOFocusID ; do we have the IO focus
|
00FFE2A2 0B1FFC010 cmpa IOFocusID ; do we have the IO focus
|
00FFE2A2 026008 bne gsl1 ; no, go pick virtual screen address
|
00FFE2A5 026008 bne gsl1 ; no, go pick virtual screen address
|
00FFE2A4 081020 cmpa #$20 ; CmodA709?
|
00FFE2A7 081020 cmpa #$20 ; CmodA709?
|
00FFE2A6 027004 beq gsl1
|
00FFE2A9 027004 beq gsl1
|
00FFE2A8 0CCE00000 ldd #TEXTSCR ; yes, we update the real screen
|
00FFE2AB 0CCE00000 ldd #TEXTSCR ; yes, we update the real screen
|
00FFE2AB 039 rts
|
00FFE2AE 039 rts
|
gsl1:
|
gsl1:
|
00FFE2AC 0CC007800 ldd #$7800
|
00FFE2AF 0CC007800 ldd #$7800
|
00FFE2AF 039 rts
|
00FFE2B2 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; HomeCursor
|
; HomeCursor
|
; Set the cursor location to the top left of the screen.
|
; Set the cursor location to the top left of the screen.
|
;
|
;
|
; Modifies:
|
; Modifies:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
HomeCursor:
|
HomeCursor:
|
00FFE2B0 034016 pshs d,x
|
00FFE2B3 034016 pshs d,x
|
00FFE2B2 00F110 clr CursorRow
|
00FFE2B5 00F110 clr CursorRow
|
00FFE2B4 00F111 clr CursorCol
|
00FFE2B7 00F111 clr CursorCol
|
00FFE2B6 0150F6FFFFFFFE0 ldb COREID
|
00FFE2B9 0150F6FFFFFFFE0 ldb COREID
|
00FFE2BB 0F1FFC010 cmpb IOFocusID
|
00FFE2BE 0F1FFC010 cmpb IOFocusID
|
00FFE2BE 02600A bne hc1
|
00FFE2C1 02600A bne hc1
|
00FFE2C0 0C1020 cmpb #$20
|
00FFE2C3 0C1020 cmpb #$20
|
00FFE2C2 027006 beq hc1
|
00FFE2C5 027006 beq hc1
|
00FFE2C4 04F clra
|
00FFE2C7 04F clra
|
00FFE2C5 0150B7FFFE07F22 sta TEXTREG+TEXT_CURPOS
|
00FFE2C8 0150B7FFFE07F22 sta TEXTREG+TEXT_CURPOS
|
hc1:
|
hc1:
|
00FFE2CA 035096 puls d,x,pc
|
00FFE2CD 035096 puls d,x,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Update the cursor position in the text controller based on the
|
; Update the cursor position in the text controller based on the
|
; CursorRow,CursorCol.
|
; CursorRow,CursorCol.
|
;
|
;
|
; Modifies:
|
; Modifies:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
UpdateCursorPos:
|
UpdateCursorPos:
|
00FFE2CC 034016 pshs d,x
|
00FFE2CF 034016 pshs d,x
|
00FFE2CE 0150F6FFFFFFFE0 ldb COREID ; update cursor position in text controller
|
00FFE2D1 0150F6FFFFFFFE0 ldb COREID ; update cursor position in text controller
|
00FFE2D3 0F1FFC010 cmpb IOFocusID ; only for the task with the output focus
|
00FFE2D6 0F1FFC010 cmpb IOFocusID ; only for the task with the output focus
|
00FFE2D6 026018 bne ucp1
|
00FFE2D9 026018 bne ucp1
|
00FFE2D8 0C1020 cmpb #$20 ; and not for CmodA709
|
00FFE2DB 0C1020 cmpb #$20 ; and not for CmodA709
|
00FFE2DA 027014 beq ucp1
|
00FFE2DD 027014 beq ucp1
|
00FFE2DC 096110 lda CursorRow
|
00FFE2DF 096110 lda CursorRow
|
00FFE2DE 08403F anda #$3F ; limit of 63 rows
|
00FFE2E1 08403F anda #$3F ; limit of 63 rows
|
00FFE2E0 0150F6FFFE07F00 ldb TEXTREG+TEXT_COLS
|
00FFE2E3 0150F6FFFE07F00 ldb TEXTREG+TEXT_COLS
|
00FFE2E5 03D mul
|
00FFE2E8 03D mul
|
00FFE2E6 01F001 tfr d,x
|
00FFE2E9 01F001 tfr d,x
|
00FFE2E8 0D6111 ldb CursorCol
|
00FFE2EB 0D6111 ldb CursorCol
|
00FFE2EA 03A abx
|
00FFE2ED 03A abx
|
00FFE2EB 0150BFFFFE07F22 stx TEXTREG+TEXT_CURPOS
|
00FFE2EE 0150BFFFFE07F22 stx TEXTREG+TEXT_CURPOS
|
ucp1:
|
ucp1:
|
00FFE2F0 035096 puls d,x,pc
|
00FFE2F3 035096 puls d,x,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Calculate screen memory location from CursorRow,CursorCol.
|
; Calculate screen memory location from CursorRow,CursorCol.
|
; Also refreshes the cursor location.
|
; Also refreshes the cursor location.
|
;
|
;
|
Line 931... |
Line 950... |
; Returns:
|
; Returns:
|
; d = screen location
|
; d = screen location
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
CalcScreenLoc:
|
CalcScreenLoc:
|
00FFE2F2 034010 pshs x
|
00FFE2F5 034010 pshs x
|
00FFE2F4 096110 lda CursorRow
|
00FFE2F7 096110 lda CursorRow
|
00FFE2F6 0C6040 ldb #COLS
|
00FFE2F9 0C6040 ldb #COLS
|
00FFE2F8 03D mul
|
00FFE2FB 03D mul
|
00FFE2F9 01F001 tfr d,x
|
00FFE2FC 01F001 tfr d,x
|
00FFE2FB 0D6111 ldb CursorCol
|
00FFE2FE 0D6111 ldb CursorCol
|
00FFE2FD 03A abx
|
00FFE300 03A abx
|
00FFE2FE 0150F6FFFFFFFE0 ldb COREID ; update cursor position in text controller
|
00FFE301 0150F6FFFFFFFE0 ldb COREID ; update cursor position in text controller
|
00FFE303 0F1FFC010 cmpb IOFocusID ; only for the task with the output focus
|
00FFE306 0F1FFC010 cmpb IOFocusID ; only for the task with the output focus
|
00FFE306 026009 bne csl1
|
00FFE309 026009 bne csl1
|
00FFE308 0C1020 cmpb #$20
|
00FFE30B 0C1020 cmpb #$20
|
00FFE30A 027005 beq csl1
|
00FFE30D 027005 beq csl1
|
00FFE30C 0150BFFFFE07F22 stx TEXTREG+TEXT_CURPOS
|
00FFE30F 0150BFFFFE07F22 stx TEXTREG+TEXT_CURPOS
|
csl1:
|
csl1:
|
00FFE311 08DF87 bsr GetScreenLocation
|
00FFE314 08DF87 bsr GetScreenLocation
|
00FFE313 03080B leax d,x
|
00FFE316 03080B leax d,x
|
00FFE315 01F010 tfr x,d
|
00FFE318 01F010 tfr x,d
|
00FFE317 035090 puls x,pc
|
00FFE31A 035090 puls x,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Display a character on the screen.
|
; Display a character on the screen.
|
; If the task doesn't have the I/O focus then the character is written to
|
; If the task doesn't have the I/O focus then the character is written to
|
; the virtual screen.
|
; the virtual screen.
|
Line 962... |
Line 981... |
; Parameters:
|
; Parameters:
|
; accb = char to display
|
; accb = char to display
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
DisplayChar:
|
DisplayChar:
|
00FFE319 01700096C lbsr SerialPutChar
|
00FFE31C 01700097B lbsr SerialPutChar
|
00FFE31C 034016 pshs d,x
|
ScreenDisplayChar:
|
00FFE31E 0C100D cmpb #CR ; carriage return ?
|
00FFE31F 034016 pshs d,x
|
00FFE320 026007 bne dccr
|
00FFE321 0C100D cmpb #CR ; carriage return ?
|
00FFE322 00F111 clr CursorCol ; just set cursor column to zero on a CR
|
00FFE323 026007 bne dccr
|
00FFE324 08DFA6 bsr UpdateCursorPos
|
00FFE325 00F111 clr CursorCol ; just set cursor column to zero on a CR
|
|
00FFE327 08DFA6 bsr UpdateCursorPos
|
dcx14:
|
dcx14:
|
00FFE326 01600008C lbra dcx4
|
00FFE329 01600008C lbra dcx4
|
dccr:
|
dccr:
|
00FFE329 0C1091 cmpb #$91 ; cursor right ?
|
00FFE32C 0C1091 cmpb #$91 ; cursor right ?
|
00FFE32B 02600D bne dcx6
|
00FFE32E 02600D bne dcx6
|
00FFE32D 096111 lda CursorCol
|
00FFE330 096111 lda CursorCol
|
00FFE32F 081040 cmpa #COLS
|
00FFE332 081040 cmpa #COLS
|
00FFE331 024003 bhs dcx7
|
00FFE334 024003 bhs dcx7
|
00FFE333 04C inca
|
00FFE336 04C inca
|
00FFE334 097111 sta CursorCol
|
00FFE337 097111 sta CursorCol
|
dcx7:
|
dcx7:
|
00FFE336 08DF94 bsr UpdateCursorPos
|
00FFE339 08DF94 bsr UpdateCursorPos
|
00FFE338 035096 puls d,x,pc
|
00FFE33B 035096 puls d,x,pc
|
dcx6:
|
dcx6:
|
00FFE33A 0C1090 cmpb #$90 ; cursor up ?
|
00FFE33D 0C1090 cmpb #$90 ; cursor up ?
|
00FFE33C 026009 bne dcx8
|
00FFE33F 026009 bne dcx8
|
00FFE33E 096110 lda CursorRow
|
00FFE341 096110 lda CursorRow
|
00FFE340 027FF4 beq dcx7
|
00FFE343 027FF4 beq dcx7
|
00FFE342 04A deca
|
00FFE345 04A deca
|
00FFE343 097110 sta CursorRow
|
00FFE346 097110 sta CursorRow
|
00FFE345 020FEF bra dcx7
|
00FFE348 020FEF bra dcx7
|
dcx8:
|
dcx8:
|
00FFE347 0C1093 cmpb #$93 ; cursor left ?
|
00FFE34A 0C1093 cmpb #$93 ; cursor left ?
|
00FFE349 026009 bne dcx9
|
00FFE34C 026009 bne dcx9
|
00FFE34B 096111 lda CursorCol
|
00FFE34E 096111 lda CursorCol
|
00FFE34D 027FE7 beq dcx7
|
00FFE350 027FE7 beq dcx7
|
00FFE34F 04A deca
|
00FFE352 04A deca
|
00FFE350 097111 sta CursorCol
|
00FFE353 097111 sta CursorCol
|
00FFE352 020FE2 bra dcx7
|
00FFE355 020FE2 bra dcx7
|
dcx9:
|
dcx9:
|
00FFE354 0C1092 cmpb #$92 ; cursor down ?
|
00FFE357 0C1092 cmpb #$92 ; cursor down ?
|
00FFE356 02600B bne dcx10
|
00FFE359 02600B bne dcx10
|
00FFE358 096110 lda CursorRow
|
00FFE35B 096110 lda CursorRow
|
00FFE35A 081020 cmpa #ROWS
|
00FFE35D 081020 cmpa #ROWS
|
00FFE35C 027FD8 beq dcx7
|
00FFE35F 027FD8 beq dcx7
|
00FFE35E 04C inca
|
00FFE361 04C inca
|
00FFE35F 097110 sta CursorRow
|
00FFE362 097110 sta CursorRow
|
00FFE361 020FD3 bra dcx7
|
00FFE364 020FD3 bra dcx7
|
dcx10:
|
dcx10:
|
00FFE363 0C1094 cmpb #$94 ; cursor home ?
|
00FFE366 0C1094 cmpb #$94 ; cursor home ?
|
00FFE365 02600C bne dcx11
|
00FFE368 02600C bne dcx11
|
00FFE367 096111 lda CursorCol
|
00FFE36A 096111 lda CursorCol
|
00FFE369 027004 beq dcx12
|
00FFE36C 027004 beq dcx12
|
00FFE36B 00F111 clr CursorCol
|
00FFE36E 00F111 clr CursorCol
|
00FFE36D 020FC7 bra dcx7
|
00FFE370 020FC7 bra dcx7
|
dcx12:
|
dcx12:
|
00FFE36F 00F110 clr CursorRow
|
00FFE372 00F110 clr CursorRow
|
00FFE371 020FC3 bra dcx7
|
00FFE374 020FC3 bra dcx7
|
dcx11:
|
dcx11:
|
00FFE373 0C1099 cmpb #$99 ; delete ?
|
00FFE376 0C1099 cmpb #$99 ; delete ?
|
00FFE375 026008 bne dcx13
|
00FFE378 026008 bne dcx13
|
00FFE377 08DF79 bsr CalcScreenLoc
|
00FFE37A 08DF79 bsr CalcScreenLoc
|
00FFE379 01F001 tfr d,x
|
00FFE37C 01F001 tfr d,x
|
00FFE37B 096111 lda CursorCol ; acc = cursor column
|
00FFE37E 096111 lda CursorCol ; acc = cursor column
|
00FFE37D 020011 bra dcx5
|
00FFE380 020011 bra dcx5
|
dcx13
|
dcx13
|
00FFE37F 0C1008 cmpb #CTRLH ; backspace ?
|
00FFE382 0C1008 cmpb #CTRLH ; backspace ?
|
00FFE381 02601E bne dcx3
|
00FFE384 02601E bne dcx3
|
00FFE383 096111 lda CursorCol
|
00FFE386 096111 lda CursorCol
|
00FFE385 02702E beq dcx4
|
00FFE388 02702E beq dcx4
|
00FFE387 04A deca
|
00FFE38A 04A deca
|
00FFE388 097111 sta CursorCol
|
00FFE38B 097111 sta CursorCol
|
00FFE38A 08DF66 bsr CalcScreenLoc
|
00FFE38D 08DF66 bsr CalcScreenLoc
|
00FFE38C 01F001 tfr d,x
|
00FFE38F 01F001 tfr d,x
|
00FFE38E 096111 lda CursorCol
|
00FFE391 096111 lda CursorCol
|
dcx5:
|
dcx5:
|
00FFE390 0E6001 ldb 1,x
|
00FFE393 0E6001 ldb 1,x
|
00FFE392 0E7801 stb ,x++
|
00FFE395 0E7801 stb ,x++
|
00FFE394 04C inca
|
00FFE397 04C inca
|
00FFE395 081040 cmpa #COLS
|
00FFE398 081040 cmpa #COLS
|
00FFE397 025FF7 blo dcx5
|
00FFE39A 025FF7 blo dcx5
|
00FFE399 0C6020 ldb #' '
|
00FFE39C 0C6020 ldb #' '
|
00FFE39B 0301FF dex
|
00FFE39E 0301FF dex
|
00FFE39D 0E7804 stb ,x
|
00FFE3A0 0E7804 stb ,x
|
00FFE39F 020014 bra dcx4
|
00FFE3A2 020014 bra dcx4
|
dcx3:
|
dcx3:
|
00FFE3A1 0C100A cmpb #LF ; linefeed ?
|
00FFE3A4 0C100A cmpb #LF ; linefeed ?
|
00FFE3A3 02700E beq dclf
|
00FFE3A6 02700E beq dclf
|
00FFE3A5 034004 pshs b
|
00FFE3A8 034004 pshs b
|
00FFE3A7 08DF49 bsr CalcScreenLoc
|
00FFE3AA 08DF49 bsr CalcScreenLoc
|
00FFE3A9 01F001 tfr d,x
|
00FFE3AC 01F001 tfr d,x
|
00FFE3AB 035004 puls b
|
00FFE3AE 035004 puls b
|
00FFE3AD 0E7804 stb ,x
|
00FFE3B0 0E7804 stb ,x
|
; ToDo character color
|
; ToDo character color
|
; lda CharColor
|
; lda CharColor
|
; sta $2000,x
|
; sta $2000,x
|
00FFE3AF 08D006 bsr IncCursorPos
|
00FFE3B2 08D006 bsr IncCursorPos
|
00FFE3B1 020002 bra dcx4
|
00FFE3B4 020002 bra dcx4
|
dclf:
|
dclf:
|
00FFE3B3 08D011 bsr IncCursorRow
|
00FFE3B6 08D011 bsr IncCursorRow
|
dcx4:
|
dcx4:
|
00FFE3B5 035096 puls d,x,pc
|
00FFE3B8 035096 puls d,x,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Increment the cursor position, scroll the screen if needed.
|
; Increment the cursor position, scroll the screen if needed.
|
;
|
;
|
; Modifies:
|
; Modifies:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
IncCursorPos:
|
IncCursorPos:
|
00FFE3B7 034016 pshs d,x
|
00FFE3BA 034016 pshs d,x
|
00FFE3B9 096111 lda CursorCol
|
00FFE3BC 096111 lda CursorCol
|
00FFE3BB 04C inca
|
00FFE3BE 04C inca
|
00FFE3BC 097111 sta CursorCol
|
00FFE3BF 097111 sta CursorCol
|
00FFE3BE 081040 cmpa #COLS
|
00FFE3C1 081040 cmpa #COLS
|
00FFE3C0 025014 blo icc1
|
00FFE3C3 025014 blo icc1
|
00FFE3C2 00F111 clr CursorCol ; column = 0
|
00FFE3C5 00F111 clr CursorCol ; column = 0
|
00FFE3C4 020002 bra icr1
|
00FFE3C7 020002 bra icr1
|
IncCursorRow:
|
IncCursorRow:
|
00FFE3C6 034016 pshs d,x
|
00FFE3C9 034016 pshs d,x
|
icr1:
|
icr1:
|
00FFE3C8 096110 lda CursorRow
|
00FFE3CB 096110 lda CursorRow
|
00FFE3CA 04C inca
|
00FFE3CD 04C inca
|
00FFE3CB 097110 sta CursorRow
|
00FFE3CE 097110 sta CursorRow
|
00FFE3CD 081020 cmpa #ROWS
|
00FFE3D0 081020 cmpa #ROWS
|
00FFE3CF 025005 blo icc1
|
00FFE3D2 025005 blo icc1
|
00FFE3D1 04A deca ; backup the cursor row, we are scrolling up
|
00FFE3D4 04A deca ; backup the cursor row, we are scrolling up
|
00FFE3D2 097110 sta CursorRow
|
00FFE3D5 097110 sta CursorRow
|
00FFE3D4 08DE8F bsr ScrollUp
|
00FFE3D7 08DE8F bsr ScrollUp
|
icc1:
|
icc1:
|
00FFE3D6 08DEF4 bsr UpdateCursorPos
|
00FFE3D9 08DEF4 bsr UpdateCursorPos
|
icc2:
|
icc2:
|
00FFE3D8 035096 puls d,x,pc
|
00FFE3DB 035096 puls d,x,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Display a string on the screen.
|
; Display a string on the screen.
|
;
|
;
|
; Modifies:
|
; Modifies:
|
Line 1103... |
Line 1123... |
; Parameters:
|
; Parameters:
|
; d = pointer to string
|
; d = pointer to string
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
DisplayString:
|
DisplayString:
|
00FFE3DA 034016 pshs d,x
|
00FFE3DD 034016 pshs d,x
|
00FFE3DC 01F001 tfr d,x
|
00FFE3DF 01F001 tfr d,x
|
00FFE3DE 0150B6FFFFFFFE0 lda COREID
|
00FFE3E1 0150B6FFFFFFFE0 lda COREID
|
00FFE3E3 081020 cmpa #$20
|
00FFE3E6 081020 cmpa #$20
|
00FFE3E5 027005 beq dspj1B
|
00FFE3E8 027005 beq dspj1B
|
dspj2: ; lock semaphore for access
|
dspj2: ; lock semaphore for access
|
00FFE3E7 0B6EF0001 lda OUTSEMA+1
|
00FFE3EA 0B6EF0001 lda OUTSEMA+1
|
00FFE3EA 027FFB beq dspj2
|
00FFE3ED 027FFB beq dspj2
|
dspj1B:
|
dspj1B:
|
00FFE3EC 0E6800 ldb ,x+ ; move string char into acc
|
00FFE3EF 0E6800 ldb ,x+ ; move string char into acc
|
00FFE3EE 027005 beq dsretB ; is it end of string ?
|
00FFE3F1 027005 beq dsretB ; is it end of string ?
|
00FFE3F0 017000AEE lbsr OUTCH ; display character
|
00FFE3F3 017000DD3 lbsr OUTCH ; display character
|
00FFE3F3 020FF7 bra dspj1B
|
00FFE3F6 020FF7 bra dspj1B
|
dsretB:
|
dsretB:
|
00FFE3F5 07FEF0001 clr OUTSEMA+1 ; unlock semaphore
|
00FFE3F8 07FEF0001 clr OUTSEMA+1 ; unlock semaphore
|
00FFE3F8 035096 puls d,x,pc
|
00FFE3FB 035096 puls d,x,pc
|
|
|
DisplayStringCRLF:
|
DisplayStringCRLF:
|
00FFE3FA 034006 pshs d
|
00FFE3FD 034006 pshs d
|
00FFE3FC 08DFDC bsr DisplayString
|
00FFE3FF 08DFDC bsr DisplayString
|
00FFE3FE 0C600D ldb #CR
|
00FFE401 0C600D ldb #CR
|
00FFE400 017000ADE lbsr OUTCH
|
00FFE403 017000DC3 lbsr OUTCH
|
00FFE403 0C600A ldb #LF
|
00FFE406 0C600A ldb #LF
|
00FFE405 017000AD9 lbsr OUTCH
|
00FFE408 017000DBE lbsr OUTCH
|
00FFE408 035086 puls d,pc
|
00FFE40B 035086 puls d,pc
|
|
|
;
|
;
|
; PRINT CR, LF, STRING
|
; PRINT CR, LF, STRING
|
;
|
;
|
PSTRNG
|
PSTRNG
|
00FFE40A 08D002 BSR PCRLF
|
00FFE40D 08D002 BSR PCRLF
|
00FFE40C 02000D BRA PDATA
|
00FFE40F 02000D BRA PDATA
|
PCRLF
|
PCRLF
|
00FFE40E 034010 PSHS X
|
00FFE411 034010 PSHS X
|
00FFE410 08EFFE422 LDX #CRLFST
|
00FFE413 08EFFE425 LDX #CRLFST
|
00FFE413 08D006 BSR PDATA
|
00FFE416 08D006 BSR PDATA
|
00FFE415 035010 PULS X
|
00FFE418 035010 PULS X
|
00FFE417 039 RTS
|
00FFE41A 039 RTS
|
|
|
PRINT
|
PRINT
|
00FFE418 0BDFFEEE1 JSR OUTCH
|
00FFE41B 0BDFFF1C9 JSR OUTCH
|
PDATA
|
PDATA
|
00FFE41B 0E6800 LDB ,X+
|
00FFE41E 0E6800 LDB ,X+
|
00FFE41D 0C1004 CMPB #$04
|
00FFE420 0C1004 CMPB #$04
|
00FFE41F 026FF7 BNE PRINT
|
00FFE422 026FF7 BNE PRINT
|
00FFE421 039 RTS
|
00FFE424 039 RTS
|
|
|
CRLFST
|
CRLFST
|
00FFE422 00D00A004 fcb CR,LF,4
|
00FFE425 00D00A004 fcb CR,LF,4
|
|
|
DispDWordAsHex:
|
DispDWordAsHex:
|
00FFE425 08D007 bsr DispWordAsHex
|
00FFE428 08D007 bsr DispWordAsHex
|
00FFE427 01E001 exg d,x
|
00FFE42A 01E001 exg d,x
|
00FFE429 08D003 bsr DispWordAsHex
|
00FFE42C 08D003 bsr DispWordAsHex
|
00FFE42B 01E001 exg d,x
|
00FFE42E 01E001 exg d,x
|
00FFE42D 039 rts
|
00FFE430 039 rts
|
|
|
DispWordAsHex:
|
DispWordAsHex:
|
00FFE42E 01E089 exg a,b
|
00FFE431 01E089 exg a,b
|
00FFE430 08D005 bsr DispByteAsHex
|
00FFE433 08D005 bsr DispByteAsHex
|
00FFE432 01E089 exg a,b
|
00FFE435 01E089 exg a,b
|
00FFE434 08D001 bsr DispByteAsHex
|
00FFE437 08D001 bsr DispByteAsHex
|
00FFE436 039 rts
|
00FFE439 039 rts
|
|
|
DispByteAsHex:
|
DispByteAsHex:
|
00FFE437 034004 pshs b
|
00FFE43A 034004 pshs b
|
00FFE439 054 lsrb
|
|
00FFE43A 054 lsrb
|
|
00FFE43B 054 lsrb
|
|
00FFE43C 054 lsrb
|
00FFE43C 054 lsrb
|
00FFE43D 054 lsrb
|
00FFE43D 054 lsrb
|
00FFE43E 054 lsrb
|
00FFE43E 054 lsrb
|
00FFE43F 054 lsrb
|
00FFE43F 054 lsrb
|
00FFE440 054 lsrb
|
00FFE440 054 lsrb
|
00FFE441 08D00C bsr DispNyb
|
00FFE441 054 lsrb
|
00FFE443 035004 puls b
|
00FFE442 054 lsrb
|
00FFE445 034004 pshs b
|
00FFE443 054 lsrb
|
00FFE447 054 lsrb
|
00FFE444 08D00C bsr DispNyb
|
00FFE448 054 lsrb
|
00FFE446 035004 puls b
|
00FFE449 054 lsrb
|
00FFE448 034004 pshs b
|
00FFE44A 054 lsrb
|
00FFE44A 054 lsrb
|
00FFE44B 08D002 bsr DispNyb
|
00FFE44B 054 lsrb
|
00FFE44D 035004 puls b
|
00FFE44C 054 lsrb
|
|
00FFE44D 054 lsrb
|
|
00FFE44E 08D002 bsr DispNyb
|
|
00FFE450 035004 puls b
|
|
|
DispNyb
|
DispNyb
|
00FFE44F 034004 pshs b
|
00FFE452 034004 pshs b
|
00FFE451 0C400F andb #$0F
|
00FFE454 0C400F andb #$0F
|
00FFE453 0C100A cmpb #10
|
00FFE456 0C100A cmpb #10
|
00FFE455 025007 blo DispNyb1
|
00FFE458 025007 blo DispNyb1
|
00FFE457 0CB037 addb #'A'-10
|
00FFE45A 0CB037 addb #'A'-10
|
00FFE459 017000A85 lbsr OUTCH
|
00FFE45C 017000D6A lbsr OUTCH
|
00FFE45C 035084 puls b,pc
|
00FFE45F 035084 puls b,pc
|
DispNyb1
|
DispNyb1
|
00FFE45E 0CB030 addb #'0'
|
00FFE461 0CB030 addb #'0'
|
00FFE460 017000A7E lbsr OUTCH
|
00FFE463 017000D63 lbsr OUTCH
|
00FFE463 035084 puls b,pc
|
00FFE466 035084 puls b,pc
|
|
|
;==============================================================================
|
;==============================================================================
|
; Timer
|
; Timer
|
;==============================================================================
|
;==============================================================================
|
|
|
Line 1230... |
Line 1250... |
; along with this program. If not, see .
|
; along with this program. If not, see .
|
;
|
;
|
; ============================================================================
|
; ============================================================================
|
;
|
;
|
TimerInit:
|
TimerInit:
|
00FFE465 0CC061A80 ldd #$61A80 ; compare to 400000 (100 Hz assuming 40MHz clock)
|
00FFE468 0CC061A80 ldd #$61A80 ; compare to 400000 (100 Hz assuming 40MHz clock)
|
00FFE468 0150F7FFFE60014 stb VIA+VIA_T3CMPL
|
00FFE46B 0150F7FFFE60014 stb VIA+VIA_T3CMPL
|
00FFE46D 0150B7FFFE60015 sta VIA+VIA_T3CMPH
|
00FFE470 0150B7FFFE60015 sta VIA+VIA_T3CMPH
|
00FFE472 01507FFFFE60012 clr VIA+VIA_T3LL
|
00FFE475 01507FFFFE60012 clr VIA+VIA_T3LL
|
00FFE477 01507FFFFE60013 clr VIA+VIA_T3LH
|
00FFE47A 01507FFFFE60013 clr VIA+VIA_T3LH
|
00FFE47C 0150B6FFFE6000B lda VIA+VIA_ACR ; set continuous mode for timer
|
00FFE47F 0150B6FFFE6000B lda VIA+VIA_ACR ; set continuous mode for timer
|
00FFE481 08A100 ora #$100
|
00FFE484 08A100 ora #$100
|
00FFE483 0150B7FFFE6000B sta VIA+VIA_ACR ; enable timer #3 interrupts
|
00FFE486 0150B7FFFE6000B sta VIA+VIA_ACR
|
00FFE488 086810 lda #$810
|
00FFE48B 086880 lda #$880 ; enable timer #3 interrupts
|
00FFE48A 0150B7FFFE6000E sta VIA+VIA_IER
|
00FFE48D 0150B7FFFE6000E sta VIA+VIA_IER
|
00FFE48F 039 rts
|
00FFE492 039 rts
|
|
|
TimerIRQ:
|
TimerIRQ:
|
; Reset the edge sense circuit in the PIC
|
; Reset the edge sense circuit in the PIC
|
00FFE490 08601F lda #31 ; Timer is IRQ #31
|
00FFE493 08601F lda #31 ; Timer is IRQ #31
|
00FFE492 0B7FFC011 sta IrqSource ; stuff a byte indicating the IRQ source for PEEK()
|
|
00FFE495 0150B7FFFE3F010 sta PIC+16 ; register 16 is edge sense reset reg
|
00FFE495 0150B7FFFE3F010 sta PIC+16 ; register 16 is edge sense reset reg
|
00FFE49A 0150B6FFFE6000D lda VIA+VIA_IFR
|
00FFE49A 0150B6FFFE3F0FF lda PIC+$FF ; Timer active interrupt flag
|
00FFE49F 02A011 bpl notTimerIRQ
|
00FFE49F 027041 beq notTimerIRQ
|
00FFE4A1 085080 bita #$80 ; timer3 irq is bit 7
|
00FFE4A1 01507FFFFE3F0FF clr PIC+$FF ; clear the flag
|
00FFE4A3 02700D beq notTimerIRQ
|
00FFE4A6 08601F lda #31 ; Timer is IRQ #31
|
00FFE4A5 01507FFFFE60012 clr VIA+VIA_T3LL
|
00FFE4A8 0B7FFC011 sta IrqSource ; stuff a byte indicating the IRQ source for PEEK()
|
00FFE4AA 01507FFFFE60013 clr VIA+VIA_T3LH
|
00FFE4AB 01507FFFFE60012 clr VIA+VIA_T3LL ; should clear the interrupt
|
00FFE4AF 07CE00037 inc $E00037 ; update timer IRQ screen flag
|
00FFE4B0 01507FFFFE60013 clr VIA+VIA_T3LH
|
|
00FFE4B5 08601F lda #31 ; Timer is IRQ #31
|
|
00FFE4B7 0150B7FFFE3F010 sta PIC+16 ; register 16 is edge sense reset reg
|
|
00FFE4BC 01507FFFFE3F0FF clr PIC+$FF ; clear the flag
|
|
00FFE4C1 07CE0003F inc $E0003F ; update timer IRQ screen flag
|
|
00FFE4C4 0FCFFC016 ldd milliseconds+2
|
|
00FFE4C7 0C300000A addd #10
|
|
00FFE4CA 0FDFFC016 std milliseconds+2
|
|
00FFE4CD 0FCFFC014 ldd milliseconds
|
|
00FFE4D0 0C9000 adcb #0
|
|
00FFE4D2 0F7FFC015 stb milliseconds+1
|
|
00FFE4D5 089000 adca #0
|
|
00FFE4D7 0B7FFC014 sta milliseconds
|
|
|
|
; Update XModem timer, we just always do it rather than testing if XModem
|
|
; is active. The increment is set to give approximately 3s before the MSB
|
|
; gets set.
|
|
00FFE4DA 0F6FFC020 ldb xm_timer
|
|
00FFE4DD 0CB004 addb #4
|
|
00FFE4DF 0F7FFC020 stb xm_timer
|
notTimerIRQ:
|
notTimerIRQ:
|
00FFE4B2 039 rts
|
00FFE4E2 039 rts
|
|
|
|
|
|
|
; ============================================================================
|
; ============================================================================
|
; __
|
; __
|
; \\__/ o\ (C) 2013-2022 Robert Finch, Waterloo
|
; \\__/ o\ (C) 2013-2022 Robert Finch, Waterloo
|
; \ __ / All rights reserved.
|
; \ __ / All rights reserved.
|
Line 1319... |
Line 1355... |
; x = I2C controller address
|
; x = I2C controller address
|
; Returns: none
|
; Returns: none
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
i2c_init:
|
i2c_init:
|
00FFE4B3 034004 pshs b
|
00FFE4E3 034004 pshs b
|
00FFE4B5 0C6004 ldb #4 ; setup prescale for 400kHz clock
|
00FFE4E5 0C6004 ldb #4 ; setup prescale for 400kHz clock
|
00FFE4B7 0E7804 stb I2C_PREL,x
|
00FFE4E7 0E7804 stb I2C_PREL,x
|
00FFE4B9 06F001 clr I2C_PREH,x
|
00FFE4E9 06F001 clr I2C_PREH,x
|
00FFE4BB 035084 puls b,pc
|
00FFE4EB 035084 puls b,pc
|
|
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; Wait for I2C transfer to complete
|
; Wait for I2C transfer to complete
|
;
|
;
|
; Parameters
|
; Parameters
|
; x - I2C controller base address
|
; x - I2C controller base address
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
i2c_wait_tip:
|
i2c_wait_tip:
|
00FFE4BD 034004 pshs b
|
00FFE4ED 034004 pshs b
|
i2cw1:
|
i2cw1:
|
00FFE4BF 0E6004 ldb I2C_STAT,x ; would use lvb, but lb is okay since its the I/O area
|
00FFE4EF 0E6004 ldb I2C_STAT,x ; would use lvb, but lb is okay since its the I/O area
|
00FFE4C1 0C5001 bitb #1 ; wait for tip to clear
|
00FFE4F1 0C5001 bitb #1 ; wait for tip to clear
|
00FFE4C3 026FFA bne i2cw1
|
00FFE4F3 026FFA bne i2cw1
|
00FFE4C5 035084 puls b,pc
|
00FFE4F5 035084 puls b,pc
|
|
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; Write command to i2c
|
; Write command to i2c
|
;
|
;
|
; Parameters
|
; Parameters
|
Line 1350... |
Line 1386... |
; acca - command value
|
; acca - command value
|
; x - I2C controller base address
|
; x - I2C controller base address
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
i2c_wr_cmd:
|
i2c_wr_cmd:
|
00FFE4C7 0E7003 stb I2C_TXR,x
|
00FFE4F7 0E7003 stb I2C_TXR,x
|
00FFE4C9 0A7004 sta I2C_CMD,x
|
00FFE4F9 0A7004 sta I2C_CMD,x
|
00FFE4CB 08DFF0 bsr i2c_wait_tip
|
00FFE4FB 08DFF0 bsr i2c_wait_tip
|
00FFE4CD 0E6004 ldb I2C_STAT,x
|
00FFE4FD 0E6004 ldb I2C_STAT,x
|
00FFE4CF 039 rts
|
00FFE4FF 039 rts
|
|
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; Parameters
|
; Parameters
|
; x - I2C controller base address
|
; x - I2C controller base address
|
; accb - data to send
|
; accb - data to send
|
; Returns: none
|
; Returns: none
|
; Stack space: 2 words
|
; Stack space: 2 words
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
i2c_xmit1:
|
i2c_xmit1:
|
00FFE4D0 034006 pshs d ; save data value
|
00FFE500 034006 pshs d ; save data value
|
00FFE4D2 034006 pshs d ; and save it again
|
00FFE502 034006 pshs d ; and save it again
|
00FFE4D4 0C6001 ldb #1
|
00FFE504 0C6001 ldb #1
|
00FFE4D6 0E7002 stb I2C_CTRL,x ; enable the core
|
00FFE506 0E7002 stb I2C_CTRL,x ; enable the core
|
00FFE4D8 0C6076 ldb #$76 ; set slave address = %0111011
|
00FFE508 0C6076 ldb #$76 ; set slave address = %0111011
|
00FFE4DA 086090 lda #$90 ; set STA, WR
|
00FFE50A 086090 lda #$90 ; set STA, WR
|
00FFE4DC 08DFE9 bsr i2c_wr_cmd
|
00FFE50C 08DFE9 bsr i2c_wr_cmd
|
00FFE4DE 08D00A bsr i2c_wait_rx_nack
|
00FFE50E 08D00A bsr i2c_wait_rx_nack
|
00FFE4E0 035006 puls d ; get back data value
|
00FFE510 035006 puls d ; get back data value
|
00FFE4E2 086050 lda #$50 ; set STO, WR
|
00FFE512 086050 lda #$50 ; set STO, WR
|
00FFE4E4 08DFE1 bsr i2c_wr_cmd
|
00FFE514 08DFE1 bsr i2c_wr_cmd
|
00FFE4E6 08D002 bsr i2c_wait_rx_nack
|
00FFE516 08D002 bsr i2c_wait_rx_nack
|
00FFE4E8 035086 puls d,pc
|
00FFE518 035086 puls d,pc
|
|
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
i2c_wait_rx_nack:
|
i2c_wait_rx_nack:
|
00FFE4EA 034004 pshs b ; save off accb
|
00FFE51A 034004 pshs b ; save off accb
|
i2cwr1:
|
i2cwr1:
|
00FFE4EC 0E6004 ldb I2C_STAT,x ; wait for RXack = 0
|
00FFE51C 0E6004 ldb I2C_STAT,x ; wait for RXack = 0
|
00FFE4EE 0C5080 bitb #$80 ; test for nack
|
00FFE51E 0C5080 bitb #$80 ; test for nack
|
00FFE4F0 026FFA bne i2cwr1
|
00FFE520 026FFA bne i2cwr1
|
00FFE4F2 035084 puls b,pc
|
00FFE522 035084 puls b,pc
|
|
|
; ============================================================================
|
; ============================================================================
|
; __
|
; __
|
; \\__/ o\ (C) 2022 Robert Finch, Waterloo
|
; \\__/ o\ (C) 2022 Robert Finch, Waterloo
|
; \ __ / All rights reserved.
|
; \ __ / All rights reserved.
|
Line 1443... |
Line 1479... |
; Modifies: d and RTCBuf
|
; Modifies: d and RTCBuf
|
; Stack space: 6 words
|
; Stack space: 6 words
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
rtc_read:
|
rtc_read:
|
00FFE4F4 08EE30500 ldx #RTC
|
00FFE524 08EE30500 ldx #RTC
|
00FFE4F7 18E007FC0 ldy #RTCBuf
|
00FFE527 18E007FC0 ldy #RTCBuf
|
00FFE4FA 0C6080 ldb #$80
|
00FFE52A 0C6080 ldb #$80
|
00FFE4FC 0E7002 stb I2C_CTRL,x ; enable I2C
|
00FFE52C 0E7002 stb I2C_CTRL,x ; enable I2C
|
00FFE4FE 0CC0900DE ldd #$900DE ; read address, write op, STA + wr bit
|
00FFE52E 0CC0900DE ldd #$900DE ; read address, write op, STA + wr bit
|
00FFE501 08DFC4 bsr i2c_wr_cmd
|
00FFE531 08DFC4 bsr i2c_wr_cmd
|
00FFE503 0C5080 bitb #$80
|
00FFE533 0C5080 bitb #$80
|
00FFE505 02603C bne rtc_rxerr
|
00FFE535 02603C bne rtc_rxerr
|
00FFE507 0CC010000 ldd #$10000 ; address zero, wr bit
|
00FFE537 0CC010000 ldd #$10000 ; address zero, wr bit
|
00FFE50A 08DFBB bsr i2c_wr_cmd
|
00FFE53A 08DFBB bsr i2c_wr_cmd
|
00FFE50C 0C5080 bitb #$80
|
00FFE53C 0C5080 bitb #$80
|
00FFE50E 026033 bne rtc_rxerr
|
00FFE53E 026033 bne rtc_rxerr
|
00FFE510 0CC0900DF ldd #$900DF ; read address, read op, STA + wr bit
|
00FFE540 0CC0900DF ldd #$900DF ; read address, read op, STA + wr bit
|
00FFE513 08DFB2 bsr i2c_wr_cmd
|
00FFE543 08DFB2 bsr i2c_wr_cmd
|
00FFE515 0C5080 bitb #$80
|
00FFE545 0C5080 bitb #$80
|
00FFE517 02602A bne rtc_rxerr
|
00FFE547 02602A bne rtc_rxerr
|
|
|
00FFE519 05F clrb
|
00FFE549 05F clrb
|
rtcr0001:
|
rtcr0001:
|
00FFE51A 086020 lda #$20
|
00FFE54A 086020 lda #$20
|
00FFE51C 0A7004 sta I2C_CMD,x ; rd bit
|
00FFE54C 0A7004 sta I2C_CMD,x ; rd bit
|
00FFE51E 08DF9D bsr i2c_wait_tip
|
00FFE54E 08DF9D bsr i2c_wait_tip
|
00FFE520 08DFC8 bsr i2c_wait_rx_nack
|
00FFE550 08DFC8 bsr i2c_wait_rx_nack
|
00FFE522 0A6004 lda I2C_STAT,x
|
00FFE552 0A6004 lda I2C_STAT,x
|
00FFE524 085080 bita #$80
|
00FFE554 085080 bita #$80
|
00FFE526 02601B bne rtc_rxerr
|
00FFE556 02601B bne rtc_rxerr
|
00FFE528 0A6003 lda I2C_RXR,x
|
00FFE558 0A6003 lda I2C_RXR,x
|
00FFE52A 0A7A07 sta b,y
|
00FFE55A 0A7A07 sta b,y
|
00FFE52C 05C incb
|
00FFE55C 05C incb
|
00FFE52D 0C105F cmpb #$5F
|
00FFE55D 0C105F cmpb #$5F
|
00FFE52F 025FE9 blo rtcr0001
|
00FFE55F 025FE9 blo rtcr0001
|
00FFE531 086068 lda #$68
|
00FFE561 086068 lda #$68
|
00FFE533 0A7004 sta I2C_CMD,x ; STO, rd bit + nack
|
00FFE563 0A7004 sta I2C_CMD,x ; STO, rd bit + nack
|
00FFE535 08DF86 bsr i2c_wait_tip
|
00FFE565 08DF86 bsr i2c_wait_tip
|
00FFE537 0A6004 lda I2C_STAT,x
|
00FFE567 0A6004 lda I2C_STAT,x
|
00FFE539 085080 bita #$80
|
00FFE569 085080 bita #$80
|
00FFE53B 026006 bne rtc_rxerr
|
00FFE56B 026006 bne rtc_rxerr
|
00FFE53D 0A6003 lda I2C_RXR,x
|
00FFE56D 0A6003 lda I2C_RXR,x
|
00FFE53F 0A7A07 sta b,y
|
00FFE56F 0A7A07 sta b,y
|
00FFE541 04F05F clrd ; return 0
|
00FFE571 04F05F clrd ; return 0
|
rtc_rxerr:
|
rtc_rxerr:
|
00FFE543 06F002 clr I2C_CTRL,x ; disable I2C and return status
|
00FFE573 06F002 clr I2C_CTRL,x ; disable I2C and return status
|
00FFE545 04F clra
|
00FFE575 04F clra
|
00FFE546 039 rts
|
00FFE576 039 rts
|
|
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; Write the real-time-clock chip.
|
; Write the real-time-clock chip.
|
;
|
;
|
; The entire contents of the clock registers and sram are written from a
|
; The entire contents of the clock registers and sram are written from a
|
Line 1501... |
Line 1537... |
; Modifies: r1 and RTCBuf
|
; Modifies: r1 and RTCBuf
|
; Stack space: 6 words
|
; Stack space: 6 words
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
rtc_write:
|
rtc_write:
|
00FFE547 08EE30500 ldx #RTC
|
00FFE577 08EE30500 ldx #RTC
|
00FFE54A 18E007FC0 ldy #RTCBuf
|
00FFE57A 18E007FC0 ldy #RTCBuf
|
|
|
00FFE54D 0C6080 ldb #$80
|
00FFE57D 0C6080 ldb #$80
|
00FFE54F 0E7002 stb I2C_CTRL,x ; enable I2C
|
00FFE57F 0E7002 stb I2C_CTRL,x ; enable I2C
|
00FFE551 0CC0900DE ldd #$900DE ; read address, write op, STA + wr bit
|
00FFE581 0CC0900DE ldd #$900DE ; read address, write op, STA + wr bit
|
00FFE554 08DF71 bsr i2c_wr_cmd
|
00FFE584 08DF71 bsr i2c_wr_cmd
|
00FFE556 0C5080 bitb #$80
|
00FFE586 0C5080 bitb #$80
|
00FFE558 026FE9 bne rtc_rxerr
|
00FFE588 026FE9 bne rtc_rxerr
|
00FFE55A 0CC010000 ldd #$10000 ; address zero, wr bit
|
00FFE58A 0CC010000 ldd #$10000 ; address zero, wr bit
|
00FFE55D 08DF68 bsr i2c_wr_cmd
|
00FFE58D 08DF68 bsr i2c_wr_cmd
|
00FFE55F 0C5080 bitb #$80
|
00FFE58F 0C5080 bitb #$80
|
00FFE561 026FE0 bne rtc_rxerr
|
00FFE591 026FE0 bne rtc_rxerr
|
|
|
00FFE563 0C6000 ldb #0
|
00FFE593 0C6000 ldb #0
|
rtcw0001:
|
rtcw0001:
|
00FFE565 034004 pshs b
|
00FFE595 034004 pshs b
|
00FFE567 0E6A05 ldb b,y
|
00FFE597 0E6A05 ldb b,y
|
00FFE569 086010 lda #$10
|
00FFE599 086010 lda #$10
|
00FFE56B 08DF5A bsr i2c_wr_cmd
|
00FFE59B 08DF5A bsr i2c_wr_cmd
|
00FFE56D 0C5080 bitb #$80
|
00FFE59D 0C5080 bitb #$80
|
00FFE56F 035004 puls b
|
00FFE59F 035004 puls b
|
00FFE571 026FD0 bne rtc_rxerr
|
00FFE5A1 026FD0 bne rtc_rxerr
|
00FFE573 05C incb
|
00FFE5A3 05C incb
|
00FFE574 0C105F cmpb #$5F
|
00FFE5A4 0C105F cmpb #$5F
|
00FFE576 025FED blo rtcw0001
|
00FFE5A6 025FED blo rtcw0001
|
00FFE578 0E6A05 ldb b,y
|
00FFE5A8 0E6A05 ldb b,y
|
00FFE57A 086050 lda #$50 ; STO, wr bit
|
00FFE5AA 086050 lda #$50 ; STO, wr bit
|
00FFE57C 08DF49 bsr i2c_wr_cmd
|
00FFE5AC 08DF49 bsr i2c_wr_cmd
|
00FFE57E 0C5080 bitb #$80
|
00FFE5AE 0C5080 bitb #$80
|
00FFE580 026FC1 bne rtc_rxerr
|
00FFE5B0 026FC1 bne rtc_rxerr
|
00FFE582 04F05F clrd ; return 0
|
00FFE5B2 04F05F clrd ; return 0
|
00FFE584 06F002 clr I2C_CTRL,x ; disable I2C and return status
|
00FFE5B4 06F002 clr I2C_CTRL,x ; disable I2C and return status
|
00FFE586 039 rts
|
00FFE5B6 039 rts
|
|
|
;==============================================================================
|
;==============================================================================
|
; Keyboard I/O
|
; Keyboard I/O
|
;==============================================================================
|
;==============================================================================
|
|
|
Line 2040... |
Line 2076... |
kbdiTryAgain:
|
kbdiTryAgain:
|
00FFEA02 0313FF dey
|
00FFEA02 0313FF dey
|
00FFEA04 026FC3 bne kbdi0002
|
00FFEA04 026FC3 bne kbdi0002
|
.keybdErr:
|
.keybdErr:
|
00FFEA06 0CCFFEA2E ldd #msgBadKeybd
|
00FFEA06 0CCFFEA2E ldd #msgBadKeybd
|
00FFEA09 017FFF9EE lbsr DisplayStringCRLF
|
00FFEA09 017FFF9F1 lbsr DisplayStringCRLF
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFEA0C 020014 bra ledxit
|
00FFEA0C 020014 bra ledxit
|
kbdi0004:
|
kbdi0004:
|
00FFEA0E 0C6002 ldb #2 ; select scan code set #2
|
00FFEA0E 0C6002 ldb #2 ; select scan code set #2
|
00FFEA10 08DF07 bsr KeybdSendByte
|
00FFEA10 08DF07 bsr KeybdSendByte
|
Line 2430... |
Line 2466... |
; d
|
; d
|
; Returns:
|
; Returns:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
|
setdp $FFC
|
|
|
InitSerial:
|
InitSerial:
|
SerialInit:
|
SerialInit:
|
00FFEBEF 04F clra
|
00FFEBEF 034008 pshs dpr
|
00FFEBF0 05F clrb
|
00FFEBF1 086FFC lda #$FFC
|
00FFEBF1 0DD130 std SerHeadRcv-1
|
00FFEBF3 01F08B tfr a,dpr
|
00FFEBF3 0DD132 std SerTailRcv-1
|
00FFEBF5 04F clra
|
00FFEBF5 0DD135 std SerHeadXmit-1
|
00FFEBF6 05F clrb
|
00FFEBF7 0DD137 std SerTailXmit-1
|
00FFEBF7 00F015 clr SerHeadRcv
|
00FFEBF9 00F139 clr SerRcvXon
|
00FFEBF9 00F016 clr SerTailRcv
|
00FFEBFB 00F140 clr SerRcvXoff
|
00FFEBFB 00F017 clr SerHeadXmit
|
00FFEBFD 0150B6FFFFFFFE0 lda COREID
|
00FFEBFD 00F018 clr SerTailXmit
|
|
00FFEBFF 00F019 clr SerRcvXon
|
|
00FFEC01 00F01A clr SerRcvXoff
|
|
00FFEC03 0150B6FFFFFFFE0 lda COREID
|
sini1:
|
sini1:
|
00FFEC02 0B1FFC010 cmpa IOFocusID
|
00FFEC08 091010 cmpa IOFocusID
|
00FFEC05 026FFB bne sini1
|
00FFEC0A 026FFC bne sini1
|
00FFEC07 0C6009 ldb #$09 ; dtr,rts active, rxint enabled, no parity
|
00FFEC0C 0C600B ldb #$0B ; dtr,rts active, rxint enabled (bit 1=0), no parity
|
00FFEC09 0150F7FFFE30102 stb ACIA+ACIA_CMD
|
00FFEC0E 0150F7FFFE30102 stb ACIA+ACIA_CMD
|
00FFEC0E 0C601E ldb #$1E ; baud 9600, 1 stop bit, 8 bit, internal baud gen
|
00FFEC13 0C601E ldb #$1E ; baud 9600, 1 stop bit, 8 bit, internal baud gen
|
00FFEC10 0150F7FFFE30103 stb ACIA+ACIA_CTRL
|
00FFEC15 0150F7FFFE30103 stb ACIA+ACIA_CTRL
|
00FFEC15 0C60A6 ldb #$0A6 ; diable fifos, reset fifos
|
00FFEC1A 0C60AC ldb #$0AC ; disable fifos (bit zero, one), reset fifos
|
00FFEC17 0150F7FFFE3010B stb ACIA+ACIA_CTRL2
|
00FFEC1C 0150F7FFFE3010B stb ACIA+ACIA_CTRL2
|
00FFEC1C 039 rts
|
00FFEC21 035088 puls dpr,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; SerialGetChar
|
; SerialGetChar
|
;
|
;
|
; Check the serial port buffer to see if there's a char available. If there's
|
; Check the serial port buffer to see if there's a char available. If there's
|
; a char available then return it. If the buffer is almost empty then send an
|
; a char available then return it. If the buffer is almost empty then send an
|
; XON.
|
; XON.
|
;
|
;
|
; Stack Space:
|
; Stack Space:
|
; 2 words
|
; 3 words
|
; Parameters:
|
; Parameters:
|
; none
|
; none
|
; Modifies:
|
; Modifies:
|
; none
|
; none
|
; Returns:
|
; Returns:
|
; d = character or -1
|
; d = character or -1
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
SerialGetChar:
|
SerialGetChar:
|
00FFEC1D 034030 pshs x,y
|
00FFEC23 034039 pshs ccr,x,y,dpr
|
00FFEC1F 18E000000 ldy #0
|
00FFEC25 086FFC lda #$FFC
|
00FFEC22 01A010 sei ; disable interrupts
|
00FFEC27 01F08B tfr a,dpr
|
00FFEC24 08D082 bsr SerialRcvCount ; check number of chars in receive buffer
|
00FFEC29 01A010 sei ; disable interrupts
|
00FFEC26 0C1008 cmpb #8 ; less than 8?
|
00FFEC2B 08D090 bsr SerialRcvCount ; check number of chars in receive buffer
|
00FFEC28 02200C bhi sgc2
|
00FFEC2D 0C1008 cmpb #8 ; less than 8?
|
00FFEC2A 0D6139 ldb SerRcvXon ; skip sending XON if already sent
|
00FFEC2F 02200C bhi sgc2
|
00FFEC2C 026008 bne sgc2 ; XON already sent?
|
00FFEC31 0D6019 ldb SerRcvXon ; skip sending XON if already sent
|
00FFEC2E 0C6011 ldb #XON ; if <8 send an XON
|
00FFEC33 026008 bne sgc2 ; XON already sent?
|
00FFEC30 00F140 clr SerRcvXoff ; clear XOFF status
|
00FFEC35 0C6011 ldb #XON ; if <8 send an XON
|
00FFEC32 0D7139 stb SerRcvXon ; flag so we don't send it multiple times
|
00FFEC37 00F01A clr SerRcvXoff ; clear XOFF status
|
00FFEC34 08D052 bsr SerialPutChar
|
00FFEC39 0D7019 stb SerRcvXon ; flag so we don't send it multiple times
|
|
00FFEC3B 08D05D bsr SerialPutChar
|
sgc2:
|
sgc2:
|
00FFEC36 0D6131 ldb SerHeadRcv ; check if anything is in buffer
|
00FFEC3D 0D6015 ldb SerHeadRcv ; check if anything is in buffer
|
00FFEC38 0D1133 cmpb SerTailRcv
|
00FFEC3F 0D1016 cmpb SerTailRcv
|
00FFEC3A 02700A beq sgcNoChars ; no?
|
00FFEC41 02700D beq sgcNoChars ; no?
|
00FFEC3C 08EBFF000 ldx #SerRcvBuf
|
00FFEC43 03080FFFB000 leax SerRcvBuf ; x = buffer address
|
00FFEC3F 04F clra
|
00FFEC47 04F clra
|
00FFEC40 0E6835 ldb b,x ; get byte from buffer
|
00FFEC48 0E680FFFB000 ldb b,x ; get byte from buffer
|
00FFEC42 00C131 inc SerHeadRcv ; 4k wrap around
|
00FFEC4C 00C015 inc SerHeadRcv ; 4k wrap around
|
00FFEC44 020003 bra sgcXit
|
00FFEC4E 020003 bra sgcXit
|
sgcNoChars:
|
sgcNoChars:
|
00FFEC46 0CCFFFFFF ldd #-1
|
00FFEC50 0CCFFFFFF ldd #-1
|
sgcXit:
|
sgcXit:
|
00FFEC49 01C0EF cli
|
00FFEC53 0350B9 puls ccr,x,y,dpr,pc
|
00FFEC4B 0350B0 puls x,y,pc
|
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; SerialPeekChar
|
; SerialPeekChar
|
;
|
;
|
; Check the serial port buffer to see if there's a char available. If there's
|
; Check the serial port buffer to see if there's a char available. If there's
|
; a char available then return it. But don't update the buffer indexes. No need
|
; a char available then return it. But don't update the buffer indexes. No need
|
; to send an XON here.
|
; to send an XON here.
|
;
|
;
|
; Stack Space:
|
; Stack Space:
|
; 0 words
|
; 2 words
|
; Parameters:
|
; Parameters:
|
; none
|
; none
|
; Modifies:
|
; Modifies:
|
; none
|
; none
|
; Returns:
|
; Returns:
|
; d = character or -1
|
; d = character or -1
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
SerialPeekChar:
|
SerialPeekChar:
|
00FFEC4D 034011 pshs x,ccr
|
00FFEC55 034019 pshs x,ccr,dpr
|
00FFEC4F 01A010 sei
|
00FFEC57 086FFC lda #$FFC
|
00FFEC51 0D6131 ldb SerHeadRcv ; check if anything is in buffer
|
00FFEC59 01F08B tfr a,dpr
|
00FFEC53 0D1133 cmpb SerTailRcv
|
00FFEC5B 01A010 sei
|
00FFEC55 027008 beq spcNoChars ; no?
|
00FFEC5D 0D6015 ldb SerHeadRcv ; check if anything is in buffer
|
00FFEC57 08EBFF000 ldx #SerRcvBuf
|
00FFEC5F 0D1016 cmpb SerTailRcv
|
00FFEC5A 04F clra
|
00FFEC61 02700B beq spcNoChars ; no?
|
00FFEC5B 0E6815 ldb b,x ; get byte from buffer
|
00FFEC63 03080FFFB000 leax SerRcvBuf
|
00FFEC5D 020003 bra spcXit
|
00FFEC67 04F clra
|
|
00FFEC68 0E680FFFB000 ldb b,x ; get byte from buffer
|
|
00FFEC6C 020003 bra spcXit
|
spcNoChars:
|
spcNoChars:
|
00FFEC5F 0CCFFFFFF ldd #-1
|
00FFEC6E 0CCFFFFFF ldd #-1
|
spcXit:
|
spcXit:
|
00FFEC62 035091 puls x,ccr,pc
|
00FFEC71 035099 puls x,ccr,dpr,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; SerialPeekChar
|
; SerialPeekChar
|
; Get a character directly from the I/O port. This bypasses the input
|
; Get a character directly from the I/O port. This bypasses the input
|
; buffer.
|
; buffer.
|
Line 2545... |
Line 2588... |
; Returns:
|
; Returns:
|
; d = character or -1
|
; d = character or -1
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
SerialPeekCharDirect:
|
SerialPeekCharDirect:
|
00FFEC64 0150B6FFFFFFFE0 lda COREID ; Ensure we have the IO Focus
|
00FFEC73 034009 pshs ccr,dpr
|
00FFEC69 0B1FFC010 cmpa IOFocusID
|
00FFEC75 086FFC lda #$FFC
|
00FFEC6C 026014 bne spcd0001
|
00FFEC77 01F08B tfr a,dpr
|
|
00FFEC79 0150B6FFFFFFFE0 lda COREID ; Ensure we have the IO Focus
|
|
00FFEC7E 091010 cmpa IOFocusID
|
|
00FFEC80 026013 bne spcd0001
|
; Disallow interrupts between status read and rx read.
|
; Disallow interrupts between status read and rx read.
|
00FFEC6E 01A010 sei
|
00FFEC82 01A010 sei
|
00FFEC70 0150F6FFFE30101 ldb ACIA+ACIA_STAT
|
00FFEC84 0150F6FFFE30101 ldb ACIA+ACIA_STAT
|
00FFEC75 0C5008 bitb #8 ; look for Rx not empty
|
00FFEC89 0C5008 bitb #8 ; look for Rx not empty
|
00FFEC77 027009 beq spcd0001
|
00FFEC8B 027008 beq spcd0001
|
00FFEC79 04F clra
|
00FFEC8D 04F clra
|
00FFEC7A 0150F6FFFE30100 ldb ACIA+ACIA_RX
|
00FFEC8E 0150F6FFFE30100 ldb ACIA+ACIA_RX
|
00FFEC7F 01C0EF cli
|
00FFEC93 035089 puls ccr,dpr,pc
|
00FFEC81 039 rts
|
|
spcd0001:
|
spcd0001:
|
00FFEC82 0CCFFFFFF ldd #-1
|
00FFEC95 0CCFFFFFF ldd #-1
|
00FFEC85 01C0EF cli
|
00FFEC98 035089 puls ccr,dpr,pc
|
00FFEC87 039 rts
|
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; SerialPutChar
|
; SerialPutChar
|
; Put a character to the serial transmitter. This routine blocks until the
|
; Put a character to the serial transmitter. This routine blocks until the
|
; transmitter is empty.
|
; transmitter is empty.
|
Line 2576... |
Line 2620... |
; Modifies:
|
; Modifies:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
SerialPutChar:
|
SerialPutChar:
|
00FFEC88 034003 pshs a,ccr
|
00FFEC9A 03400B pshs a,ccr,dpr
|
|
00FFEC9C 086FFC lda #$FFC
|
|
00FFEC9E 01F08B tfr a,dpr
|
spc0001:
|
spc0001:
|
00FFEC8A 0150B6FFFFFFFE0 lda COREID ; Ensure we have the IO Focus
|
00FFECA0 0150B6FFFFFFFE0 lda COREID ; Ensure we have the IO Focus
|
00FFEC8F 0B1FFC010 cmpa IOFocusID
|
00FFECA5 091010 cmpa IOFocusID
|
00FFEC92 026FF6 bne spc0001
|
00FFECA7 026FF7 bne spc0001
|
00FFEC94 01C0EF cli ; provide a window for an interrupt to occur
|
00FFECA9 01C0EF cli ; provide a window for an interrupt to occur
|
00FFEC96 01A010 sei
|
00FFECAB 01A010 sei
|
; Between the status read and the transmit do not allow an
|
; Between the status read and the transmit do not allow an
|
; intervening interrupt.
|
; intervening interrupt.
|
00FFEC98 0150B6FFFE30101 lda ACIA+ACIA_STAT ; wait until the uart indicates tx empty
|
00FFECAD 0150B6FFFE30101 lda ACIA+ACIA_STAT ; wait until the uart indicates tx empty
|
00FFEC9D 085010 bita #16 ; bit #4 of the status reg
|
00FFECB2 085010 bita #16 ; bit #4 of the status reg
|
00FFEC9F 027FE9 beq spc0001 ; branch if transmitter is not empty
|
00FFECB4 027FEA beq spc0001 ; branch if transmitter is not empty
|
00FFECA1 0150F7FFFE30100 stb ACIA+ACIA_TX ; send the byte
|
00FFECB6 0150F7FFFE30100 stb ACIA+ACIA_TX ; send the byte
|
00FFECA6 035083 puls a,ccr,pc
|
00FFECBB 03508B puls a,ccr,dpr,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Calculate number of character in input buffer
|
; Calculate number of character in input buffer. Direct page must be set
|
|
; already.
|
;
|
;
|
; Parameters:
|
; Parameters:
|
; y = 0 if current core, otherwise reference to core memory area $Cyxxxx
|
; none
|
; Returns:
|
; Returns:
|
; d = number of bytes in buffer.
|
; d = number of bytes in buffer.
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
SerialRcvCount:
|
SerialRcvCount:
|
00FFECA8 04F clra
|
00FFECBD 04F clra
|
00FFECA9 0E6A08133 ldb SerTailRcv,y
|
00FFECBE 0D6016 ldb SerTailRcv
|
00FFECAC 0E0A08131 subb SerHeadRcv,y
|
00FFECC0 0D0015 subb SerHeadRcv
|
00FFECAF 02C009 bge srcXit
|
00FFECC2 02C007 bge srcXit
|
00FFECB1 0CC001000 ldd #$1000
|
00FFECC4 0CC001000 ldd #$1000
|
00FFECB4 0A3A08131 subd SerHeadRcv,y
|
00FFECC7 093015 subd SerHeadRcv
|
00FFECB7 0E3A08133 addd SerTailRcv,y
|
00FFECC9 0D3016 addd SerTailRcv
|
srcXit:
|
srcXit:
|
00FFECBA 039 rts
|
00FFECCB 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Serial IRQ routine
|
; Serial IRQ routine
|
;
|
;
|
; Keeps looping as long as it finds characters in the ACIA recieve buffer/fifo.
|
; Keeps looping as long as it finds characters in the ACIA recieve buffer/fifo.
|
Line 2627... |
Line 2674... |
; Returns:
|
; Returns:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
SerialIRQ:
|
SerialIRQ:
|
|
00FFECCC 034008 pshs dpr ; set direct page register to boot variables
|
|
00FFECCE 086FFC lda #$FFC
|
|
00FFECD0 01F08B tfr a,dpr
|
|
00FFECD2 0150B6FFFE3F0D3 lda PIC+$D3 ; Serial active interrupt flag
|
|
00FFECD7 027042 beq notSerInt
|
sirqNxtByte:
|
sirqNxtByte:
|
00FFECBB 0150F6FFFE30101 ldb ACIA+ACIA_STAT ; check the status
|
00FFECD9 0150F6FFFE30104 ldb ACIA+ACIA_IRQS ; look for IRQs
|
00FFECC0 0C5008 bitb #$08 ; bit 3 = rx full
|
00FFECDE 02A03B bpl notSerInt ; quick test for any irqs
|
00FFECC2 027049 beq notRxInt
|
00FFECE0 0150F6FFFE30101 ldb ACIA+ACIA_STAT ; check the status
|
00FFECC4 0150F6FFFE30100 ldb ACIA+ACIA_RX ; get data from Rx buffer to clear interrupt
|
00FFECE5 0C5008 bitb #$08 ; bit 3 = rx full (not empty)
|
00FFECC9 0C1014 cmpb #CTRLT ; detect special keystroke
|
00FFECE7 027030 beq notRxInt1
|
00FFECCB 026000 bne sirq0001
|
00FFECE9 0150F6FFFE30100 ldb ACIA+ACIA_RX ; get data from Rx buffer to clear interrupt
|
; bsr DumpTraceQueue
|
00FFECEE 096016 lda SerTailRcv ; check if recieve buffer full
|
sirq0001:
|
00FFECF0 04C inca
|
00FFECCD 034004 pshs b
|
00FFECF1 091015 cmpa SerHeadRcv
|
; Compute receive buffer address
|
00FFECF3 027026 beq sirqRxFull
|
00FFECCF 0B6FFC010 lda IOFocusID
|
00FFECF5 097016 sta SerTailRcv ; update tail pointer
|
00FFECD2 048 asla
|
00FFECF7 04A deca ; backup
|
00FFECD3 048 asla
|
00FFECF8 01E089 exg a,b
|
00FFECD4 048 asla
|
00FFECFA 03080FFFB000 leax SerRcvBuf ; x = buffer address
|
00FFECD5 048 asla
|
00FFECFE 0A780FFFB000 sta b,x ; store recieved byte in buffer
|
00FFECD6 08AC00 ora #$C00
|
00FFED02 00D01A tst SerRcvXoff ; check if xoff already sent
|
00FFECD8 05F clrb
|
00FFED04 026FD3 bne sirqNxtByte
|
00FFECD9 01F002 tfr d,y
|
00FFED06 08DFB5 bsr SerialRcvCount ; if more than 4070 chars in buffer
|
00FFECDB 035004 puls b
|
00FFED08 0C1FE6 cmpb #4070
|
00FFECDD 0A6A08133 lda SerTailRcv,y ; check if recieve buffer full
|
00FFED0A 025FCD blo sirqNxtByte
|
00FFECE0 04C inca
|
00FFED0C 0C6013 ldb #XOFF ; send an XOFF
|
00FFECE1 0A1A08131 cmpa SerHeadRcv,y
|
00FFED0E 00F019 clr SerRcvXon ; clear XON status
|
00FFECE4 027027 beq sirqRxFull
|
00FFED10 0D701A stb SerRcvXoff ; set XOFF status
|
00FFECE6 0A7A08133 sta SerTailRcv,y ; update tail pointer
|
00FFED12 0150F7FFFE30100 stb ACIA+ACIA_TX
|
00FFECE9 04A deca ; backup
|
00FFED17 020FC0 bra sirqNxtByte ; check the status for another byte
|
00FFECEA 01E089 exg a,b
|
; Process other serial IRQs
|
00FFECEC 030A0A000BFF000 leax SerRcvBuf,y ; x = buffer address
|
notRxInt1:
|
00FFECF1 0A7A0F sta b,x ; store recieved byte in buffer
|
00FFED19 035088 puls dpr,pc
|
00FFECF3 06DA08140 tst SerRcvXoff,y ; check if xoff already sent
|
|
00FFECF6 026FC3 bne sirqNxtByte
|
|
00FFECF8 08DFAE bsr SerialRcvCount ; if more than 4080 chars in buffer
|
|
00FFECFA 0C1FF0 cmpb #4080
|
|
00FFECFC 025FBD blo sirqNxtByte
|
|
00FFECFE 0C6013 ldb #XOFF ; send an XOFF
|
|
00FFED00 06FA08139 clr SerRcvXon,y ; clear XON status
|
|
00FFED03 0E7A08140 stb SerRcvXoff,y ; set XOFF status
|
|
00FFED06 0150F7FFFE30100 stb ACIA+ACIA_TX
|
|
00FFED0B 020FAE bra sirqNxtByte ; check the status for another byte
|
|
sirqRxFull:
|
sirqRxFull:
|
notRxInt:
|
notRxInt:
|
00FFED0D 039 rts
|
notSerInt:
|
|
00FFED1B 035088 puls dpr,pc
|
|
|
nmeSerial:
|
nmeSerial:
|
00FFED0E 05306507206906106C000 fcb "Serial",0
|
00FFED1D 05306507206906106C000 fcb "Serial",0
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Put a string to the serial port.
|
; Put a string to the serial port.
|
;
|
;
|
; Parameters:
|
; Parameters:
|
Line 2685... |
Line 2728... |
; Returns:
|
; Returns:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
SerialPutString:
|
SerialPutString:
|
00FFED15 034016 pshs d,x
|
00FFED24 034016 pshs d,x
|
00FFED17 01F001 tfr d,x
|
00FFED26 01F001 tfr d,x
|
sps2:
|
sps2:
|
00FFED19 0E6804 ldb ,x
|
00FFED28 0E6804 ldb ,x
|
00FFED1B 027006 beq spsXit
|
00FFED2A 027006 beq spsXit
|
00FFED1D 030001 inx
|
00FFED2C 030001 inx
|
00FFED1F 08DF67 bsr SerialPutChar
|
00FFED2E 08DF6A bsr SerialPutChar
|
00FFED21 020FF6 bra sps2
|
00FFED30 020FF6 bra sps2
|
spsXit:
|
spsXit:
|
00FFED23 035096 puls d,x,pc
|
00FFED32 035096 puls d,x,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; A little routine to test serial output.
|
; A little routine to test serial output.
|
;
|
;
|
; Parameters:
|
; Parameters:
|
Line 2708... |
Line 2751... |
; Returns:
|
; Returns:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
SerialOutputTest:
|
SerialOutputTest:
|
00FFED25 034006 pshs d
|
00FFED34 034006 pshs d
|
00FFED27 0CCFFED45 ldd #msgSerialTest
|
00FFED36 0CCFFED54 ldd #msgSerialTest
|
00FFED2A 017FFF6AD lbsr DisplayString
|
00FFED39 017FFF6A1 lbsr DisplayString
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFED2D 08DEC0 bsr SerialInit
|
00FFED3C 08DEB1 bsr SerialInit
|
sotst1:
|
sotst1:
|
00FFED2F 0C6011 ldb #XON
|
00FFED3E 0C6011 ldb #XON
|
00FFED31 08DF55 bsr SerialPutChar
|
00FFED40 08DF58 bsr SerialPutChar
|
00FFED33 08DF53 bsr SerialPutChar
|
00FFED42 08DF56 bsr SerialPutChar
|
00FFED35 08DF51 bsr SerialPutChar
|
00FFED44 08DF54 bsr SerialPutChar
|
00FFED37 0CCFFED45 ldd #msgSerialTest
|
00FFED46 0CCFFED54 ldd #msgSerialTest
|
00FFED3A 08DFD9 bsr SerialPutString
|
00FFED49 08DFD9 bsr SerialPutString
|
00FFED3C 01700016A lbsr INCH
|
00FFED4B 017000443 lbsr INCH
|
00FFED3F 0C1003 cmpb #CTRLC
|
00FFED4E 0C1003 cmpb #CTRLC
|
00FFED41 026FEC bne sotst1
|
00FFED50 026FEC bne sotst1
|
00FFED43 035086 puls d,pc
|
00FFED52 035086 puls d,pc
|
|
|
msgSerialTest:
|
msgSerialTest:
|
00FFED45 05306507206906106C020 fcb "Serial port test",CR,LF,0
|
00FFED54 05306507206906106C020 fcb "Serial port test",CR,LF,0
|
00FFED4C 07006F072074020074065
|
00FFED5B 07006F072074020074065
|
00FFED53 07307400D00A000
|
00FFED62 07307400D00A000
|
|
|
|
setdp $000
|
; ============================================================================
|
; ============================================================================
|
; __
|
; __
|
; \\__/ o\ (C) 2022 Robert Finch, Waterloo
|
; \\__/ o\ (C) 2022 Robert Finch, Waterloo
|
; \ __ / All rights reserved.
|
; \ __ / All rights reserved.
|
; \/_// robfinch@opencores.org
|
; \/_// robfinch@opencores.org
|
Line 2766... |
Line 2810... |
; OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
; OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
; OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
; OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
;
|
;
|
; ============================================================================
|
; ============================================================================
|
;
|
;
|
|
; S19 variables
|
|
;
|
s19Address EQU $940 ; to $943
|
s19Address EQU $940 ; to $943
|
s19StartAddress EQU $944 ; to $947
|
s19StartAddress EQU $944 ; to $947
|
s19Rectype EQU $948
|
s19Rectype EQU $948
|
s19Reclen EQU $949
|
s19Reclen EQU $949
|
s19Abort EQU $94A
|
s19Abort EQU $94A
|
|
s19Checksum EQU $94B
|
|
s19SummaryChecksum EQU $94C
|
|
s19Source EQU $94E
|
|
s19XferAddress EQU $950 ; to $951
|
|
|
|
; ------------------------------------------------------------------------------
|
|
; Input a character either from a file in memory or from the serial port.
|
|
;
|
|
; Parameters:
|
|
; none
|
|
; Returns:
|
|
; accb = character input
|
|
; ------------------------------------------------------------------------------
|
|
|
|
s19InputChar:
|
|
00FFED67 07D00094E tst s19Source
|
|
00FFED6A 02700D beq s19ic1
|
|
00FFED6C 0E690F000950 ldb [s19XferAddress]
|
|
00FFED70 07C000951 inc s19XferAddress+1 ; increment low byte of address pointer
|
|
00FFED73 026003 bne s19ic2
|
|
00FFED75 07C000950 inc s19XferAddress ; increment high byte of address pointer
|
|
s19ic2:
|
|
00FFED78 039 rts
|
|
s19ic1:
|
|
00FFED79 0CCFFFFFF ldd #-1 ; block until input is available
|
|
00FFED7C 03F swi
|
|
00FFED7D 001 fcb MF_INCH ; monitor input rout
|
|
00FFED7E 039 rts
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Skip over input to the next record.
|
; Skip over input to the next record.
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19NextRecord:
|
s19NextRecord:
|
00FFED58 0CCFFFFFF ldd #-1 ; block until input is available
|
00FFED7F 08DFE6 bsr s19InputChar
|
00FFED5B 03F swi
|
00FFED81 0C100A cmpb #LF ; line feed marks end of record
|
00FFED5C 001 fcb MF_INCH ; monitor input rout
|
00FFED83 027013 beq s19nr1
|
00FFED5D 0C100A cmpb #LF ; line feed marks end of record
|
00FFED85 0C1003 cmpb #CTRLC ; should not get this in a file transfer
|
00FFED5F 027013 beq s19nr1
|
00FFED87 026003 bne s19nr2
|
00FFED61 0C1003 cmpb #CTRLC ; should not get this in a file transfer
|
00FFED89 0F700094A stb s19Abort
|
00FFED63 026003 bne s19nr2
|
|
00FFED65 0F700094A stb s19Abort
|
|
s19nr2:
|
s19nr2:
|
00FFED68 0C101A cmpb #CTRLZ ; end of file marker?
|
00FFED8C 0C101A cmpb #CTRLZ ; end of file marker?
|
00FFED6A 026003 bne s19nr3
|
00FFED8E 026003 bne s19nr3
|
00FFED6C 0F700094A stb s19Abort
|
00FFED90 0F700094A stb s19Abort
|
s19nr3:
|
s19nr3:
|
00FFED6F 07D00094A tst s19Abort
|
00FFED93 07D00094A tst s19Abort
|
00FFED72 027FE4 beq s19NextRecord
|
00FFED96 027FE7 beq s19NextRecord
|
s19nr1:
|
s19nr1:
|
00FFED74 039 rts
|
00FFED98 039 rts
|
|
|
|
; ------------------------------------------------------------------------------
|
|
; Update the checksum.
|
|
; ------------------------------------------------------------------------------
|
|
|
|
s19AddCheck:
|
|
00FFED99 034004 pshs b
|
|
00FFED9B 0FB00094B addb s19Checksum
|
|
00FFED9E 0F700094B stb s19Checksum
|
|
00FFEDA1 035084 puls b,pc
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Input a byte. There are three characters per byte since things are 12-bit.
|
; Input a byte. There are three characters per byte since things are 12-bit.
|
;
|
;
|
; Parameters:
|
; Parameters:
|
Line 2805... |
Line 2887... |
; Returns:
|
; Returns:
|
; accb = byte value converted from text
|
; accb = byte value converted from text
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19GetByte:
|
s19GetByte:
|
00FFED75 03F swi
|
00FFEDA3 08DFC2 bsr s19InputChar ; get the first character
|
00FFED76 001 fcb MF_INCH ; get the first character
|
00FFEDA5 0170007F7 lbsr AsciiToHexNybble ; convert to nybble
|
00FFED77 0170004F6 lbsr AsciiToHexNybble ; convert to nybble
|
00FFEDA8 07D00094A tst s19Abort ; check for abort
|
00FFED7A 07D00094A tst s19Abort ; check for abort
|
00FFEDAB 027002 beq s19gb1
|
00FFED7D 027002 beq s19gb1
|
00FFEDAD 04F clra
|
00FFED7F 04F clra
|
00FFEDAE 039 rts
|
00FFED80 039 rts
|
|
s19gb1: ; shift the value four bits
|
s19gb1: ; shift the value four bits
|
00FFED81 058 aslb
|
00FFEDAF 058 aslb
|
00FFED82 058 aslb
|
00FFEDB0 058 aslb
|
00FFED83 058 aslb
|
00FFEDB1 058 aslb
|
00FFED84 058 aslb
|
00FFEDB2 058 aslb
|
00FFED85 034004 pshs b ; save off value
|
00FFEDB3 034004 pshs b ; save off value
|
00FFED87 03F swi
|
00FFEDB5 08DFB0 bsr s19InputChar ; get the second character
|
00FFED88 001 fcb MF_INCH ; get the second character
|
00FFEDB7 0170007E5 lbsr AsciiToHexNybble ; convert to nybble
|
00FFED89 0170004E4 lbsr AsciiToHexNybble ; convert to nybble
|
00FFEDBA 07D00094A tst s19Abort ; check for abort
|
00FFED8C 07D00094A tst s19Abort ; check for abort
|
00FFEDBD 026011 bne s19gb2
|
00FFED8F 026011 bne s19gb2
|
00FFEDBF 0EAE00 orb ,s+ ; merge new nybble into value
|
00FFED91 0EAE00 orb ,s+ ; merge new nybble into value
|
00FFEDC1 058 aslb ; shift the value four more bits
|
00FFED93 058 aslb ; shift the value four more bits
|
00FFEDC2 058 aslb
|
00FFED94 058 aslb
|
00FFEDC3 058 aslb
|
00FFED95 058 aslb
|
00FFEDC4 058 aslb
|
00FFED96 058 aslb
|
00FFEDC5 034004 pshs b ; save off value
|
00FFED97 034004 pshs b ; save off value
|
00FFEDC7 08DF9E bsr s19InputChar ; get the third character
|
00FFED99 03F swi
|
00FFEDC9 0170007D3 lbsr AsciiToHexNybble ; convert to nybble
|
00FFED9A 001 fcb MF_INCH ; get third character
|
00FFEDCC 0EAE00 orb ,s+ ; merge in value
|
00FFED9B 0170004D2 lbsr AsciiToHexNybble ; convert to nybble
|
00FFEDCE 04F clra ; make byte 000 to FFF in D
|
00FFED9E 0EAE00 orb ,s+ ; merge in value
|
00FFEDCF 039 rts
|
00FFEDA0 04F clra ; make byte 000 to FFF in D
|
|
00FFEDA1 039 rts
|
|
s19gb2:
|
s19gb2:
|
00FFEDA2 032601 leas 1,s ; discard saved byte
|
00FFEDD0 032601 leas 1,s ; discard saved byte
|
00FFEDA4 04F clra
|
00FFEDD2 04F clra
|
00FFEDA5 039 rts
|
00FFEDD3 039 rts
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Zero out address
|
; Zero out address
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19ClearAddress:
|
s19ClearAddress:
|
00FFEDA6 07F000940 clr s19Address
|
00FFEDD4 07F000940 clr s19Address
|
00FFEDA9 07F000941 clr s19Address+1
|
00FFEDD7 07F000941 clr s19Address+1
|
00FFEDAC 07F000942 clr s19Address+2
|
00FFEDDA 07F000942 clr s19Address+2
|
00FFEDAF 07F000943 clr s19Address+3
|
00FFEDDD 07F000943 clr s19Address+3
|
00FFEDB2 039 rts
|
00FFEDE0 039 rts
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Get an address composed of two bytes (24 bit)
|
; Get an address composed of two bytes (24 bit)
|
;
|
;
|
; Side Effects:
|
; Side Effects:
|
Line 2861... |
Line 2940... |
; Returns:
|
; Returns:
|
; none
|
; none
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19GetAddress2:
|
s19GetAddress2:
|
00FFEDB3 08DFF1 bsr s19ClearAddress
|
00FFEDE1 08DFF1 bsr s19ClearAddress
|
00FFEDB5 08DFBE bsr s19GetByte
|
00FFEDE3 08DFBE bsr s19GetByte
|
00FFEDB7 0F7000942 stb s19Address+2
|
00FFEDE5 08DFB2 bsr s19AddCheck
|
00FFEDBA 07D00094A tst s19Abort
|
00FFEDE7 0F7000942 stb s19Address+2
|
00FFEDBD 026005 bne s19ga1
|
00FFEDEA 07D00094A tst s19Abort
|
00FFEDBF 08DFB4 bsr s19GetByte
|
00FFEDED 026007 bne s19ga1
|
00FFEDC1 0F7000943 stb s19Address+3
|
00FFEDEF 08DFB2 bsr s19GetByte
|
|
00FFEDF1 08DFA6 bsr s19AddCheck
|
|
00FFEDF3 0F7000943 stb s19Address+3
|
s19ga1:
|
s19ga1:
|
00FFEDC4 039 rts
|
00FFEDF6 039 rts
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Get an address composed of three bytes (36 bit)
|
; Get an address composed of three bytes (36 bit)
|
;
|
;
|
; Side Effects:
|
; Side Effects:
|
Line 2881... |
Line 2962... |
; Returns:
|
; Returns:
|
; none
|
; none
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19GetAddress3:
|
s19GetAddress3:
|
00FFEDC5 08DFDF bsr s19ClearAddress
|
00FFEDF7 08DFDB bsr s19ClearAddress
|
00FFEDC7 08DFAC bsr s19GetByte
|
00FFEDF9 08DFA8 bsr s19GetByte
|
00FFEDC9 0F7000941 stb s19Address+1
|
00FFEDFB 08DF9C bsr s19AddCheck
|
00FFEDCC 07D00094A tst s19Abort
|
00FFEDFD 0F7000941 stb s19Address+1
|
00FFEDCF 02600F bne s19ga2
|
00FFEE00 07D00094A tst s19Abort
|
00FFEDD1 08DFA2 bsr s19GetByte
|
00FFEE03 026013 bne s19ga2
|
00FFEDD3 0F7000942 stb s19Address+2
|
00FFEE05 08DF9C bsr s19GetByte
|
00FFEDD6 07D00094A tst s19Abort
|
00FFEE07 08DF90 bsr s19AddCheck
|
00FFEDD9 026005 bne s19ga2
|
00FFEE09 0F7000942 stb s19Address+2
|
00FFEDDB 08DF98 bsr s19GetByte
|
00FFEE0C 07D00094A tst s19Abort
|
00FFEDDD 0F7000943 stb s19Address+3
|
00FFEE0F 026007 bne s19ga2
|
|
00FFEE11 08DF90 bsr s19GetByte
|
|
00FFEE13 08DF84 bsr s19AddCheck
|
|
00FFEE15 0F7000943 stb s19Address+3
|
s19ga2:
|
s19ga2:
|
00FFEDE0 039 rts
|
00FFEE18 039 rts
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Put a byte to memory.
|
; Put a byte to memory.
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19PutMem:
|
s19PutMem:
|
00FFEDE1 05F clrb ; accb = current byte count
|
00FFEE19 05F clrb ; accb = current byte count
|
s19pm3:
|
s19pm3:
|
00FFEDE2 034004 pshs b ; save byte count
|
00FFEE1A 034004 pshs b ; save byte count
|
00FFEDE4 08DF8F bsr s19GetByte
|
00FFEE1C 08DF85 bsr s19GetByte
|
00FFEDE6 07D00094A tst s19Abort
|
00FFEE1E 08DF79 bsr s19AddCheck
|
00FFEDE9 02601C bne s19pm1
|
00FFEE20 07D00094A tst s19Abort
|
00FFEDEB 0150E790F000941 stb far [s19Address+1] ; store the byte using far addressing
|
00FFEE23 02601E bne s19pm1
|
00FFEDF0 07C000943 inc s19Address+3
|
00FFEE25 0150E790F000941 stb far [s19Address+1] ; store the byte using far addressing
|
00FFEDF3 026008 bne s19pm2
|
00FFEE2A 07C000943 inc s19Address+3
|
00FFEDF5 07C000942 inc s19Address+2
|
00FFEE2D 026008 bne s19pm2
|
00FFEDF8 026003 bne s19pm2
|
00FFEE2F 07C000942 inc s19Address+2
|
00FFEDFA 07C000941 inc s19Address+1
|
00FFEE32 026003 bne s19pm2
|
|
00FFEE34 07C000941 inc s19Address+1
|
s19pm2:
|
s19pm2:
|
00FFEDFD 035004 puls b ; get back byte count
|
00FFEE37 035004 puls b ; get back byte count
|
00FFEDFF 05C incb ; increment and
|
00FFEE39 05C incb ; increment and
|
00FFEE00 0F1000949 cmpb s19Reclen ; compare to record length
|
00FFEE3A 0F1000949 cmpb s19Reclen ; compare to record length
|
00FFEE03 025FDD blo s19pm3
|
00FFEE3D 025FDB blo s19pm3
|
00FFEE05 020F6E bra s19GetByte ; get the checksum byte
|
00FFEE3F 08DF62 bsr s19GetByte ; get the checksum byte
|
|
00FFEE41 020F56 bra s19AddCheck
|
s19pm1:
|
s19pm1:
|
00FFEE07 032601 leas 1,s ; faster than actual pull
|
00FFEE43 032601 leas 1,s ; faster than actual pull
|
00FFEE09 020F6A bra s19GetByte ; get the checksum byte
|
00FFEE45 08DF5C bsr s19GetByte ; get the checksum byte
|
|
00FFEE47 020F50 bra s19AddCheck
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Processing for S1 record type.
|
; Processing for S1 record type.
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19ProcessS1:
|
s19ProcessS1:
|
00FFEE0B 08DFA6 bsr s19GetAddress2
|
00FFEE49 08DF96 bsr s19GetAddress2
|
00FFEE0D 08DFD2 bsr s19PutMem
|
00FFEE4B 08DFCC bsr s19PutMem
|
00FFEE0F 020072 bra s19lnr
|
00FFEE4D 07D00094B tst s19Checksum
|
|
00FFEE50 027008 beq s19p11
|
|
00FFEE52 07C00094C inc s19SummaryChecksum
|
|
00FFEE55 0CCFFEF19 ldd #msgChecksumErr
|
|
00FFEE58 03F swi
|
|
00FFEE59 004 fcb MF_DisplayString
|
|
s19p11:
|
|
00FFEE5A 020099 bra s19lnr
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Processing for S2 record type.
|
; Processing for S2 record type.
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19ProcessS2:
|
s19ProcessS2:
|
00FFEE11 08DFB2 bsr s19GetAddress3
|
00FFEE5C 08DF99 bsr s19GetAddress3
|
00FFEE13 08DFCC bsr s19PutMem
|
00FFEE5E 08DFB9 bsr s19PutMem
|
00FFEE15 02006C bra s19lnr
|
00FFEE60 07D00094B tst s19Checksum
|
|
00FFEE63 027008 beq s19p21
|
|
00FFEE65 07C00094C inc s19SummaryChecksum
|
|
00FFEE68 0CCFFEF19 ldd #msgChecksumErr
|
|
00FFEE6B 03F swi
|
|
00FFEE6C 004 fcb MF_DisplayString
|
|
s19p21:
|
|
00FFEE6D 020086 bra s19lnr
|
|
|
; S3,4,5,6 not processed
|
; S3,4,5,6 not processed
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Processing for S7 record type. Gets a two byte (24 bit) start address.
|
; Processing for S7 record type. Gets a two byte (24 bit) start address.
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19ProcessS9:
|
s19ProcessS9:
|
00FFEE17 08DF9A bsr s19GetAddress2
|
00FFEE6F 08DF70 bsr s19GetAddress2
|
00FFEE19 0FC000942 ldd s19Address+2
|
00FFEE71 0FC000942 ldd s19Address+2
|
00FFEE1C 0FD000946 std s19StartAddress+2
|
00FFEE74 0FD000946 std s19StartAddress+2
|
00FFEE1F 0FC000940 ldd s19Address+0
|
00FFEE77 0FC000940 ldd s19Address+0
|
00FFEE22 0FD000944 std s19StartAddress+0
|
00FFEE7A 0FD000944 std s19StartAddress+0
|
00FFEE25 020069 bra s19l2
|
00FFEE7D 020083 bra s19l2
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; Processing for S8 record type. Gets a three byte (36 bit) start address.
|
; Processing for S8 record type. Gets a three byte (36 bit) start address.
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
s19ProcessS8:
|
s19ProcessS8:
|
00FFEE27 08DF9C bsr s19GetAddress3
|
00FFEE7F 08DF76 bsr s19GetAddress3
|
00FFEE29 0FC000942 ldd s19Address+2
|
00FFEE81 0FC000942 ldd s19Address+2
|
00FFEE2C 0FD000946 std s19StartAddress+2
|
00FFEE84 0FD000946 std s19StartAddress+2
|
00FFEE2F 0FC000940 ldd s19Address+0
|
00FFEE87 0FC000940 ldd s19Address+0
|
00FFEE32 0FD000944 std s19StartAddress+0
|
00FFEE8A 0FD000944 std s19StartAddress+0
|
00FFEE35 020059 bra s19l2
|
00FFEE8D 020073 bra s19l2
|
|
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
; S19 Loader
|
; S19 Loader
|
;
|
;
|
; Not all record types are processed. Some are skipped over.
|
; Not all record types are processed. Some are skipped over.
|
; ------------------------------------------------------------------------------
|
; ------------------------------------------------------------------------------
|
|
|
S19Loader:
|
S19Loader:
|
00FFEE37 07F00094A clr s19Abort ; clear the abort flag
|
00FFEE8F 07F00094E clr s19Source
|
00FFEE3A 0CCFFEE93 ldd #msgS19Loader ; signon banner
|
00FFEE92 0170006FC lbsr GetNumber ; check for a file storage address
|
00FFEE3D 03F swi
|
00FFEE95 05D tstb
|
00FFEE3E 004 fcb MF_DisplayString
|
00FFEE96 027009 beq s19l4 ; if not a memory file
|
|
00FFEE98 07C00094E inc s19Source ; set flag indicating a memory file
|
|
00FFEE9B 0FC000912 ldd mon_numwka+2 ; set transfer address variable
|
|
00FFEE9E 0FD000950 std s19XferAddress
|
|
s19l4:
|
|
00FFEEA1 07F00094A clr s19Abort ; clear the abort flag
|
|
00FFEEA4 0CCFFEF05 ldd #msgS19Loader ; signon banner
|
|
00FFEEA7 03F swi
|
|
00FFEEA8 004 fcb MF_DisplayString
|
|
00FFEEA9 07F00094C clr s19SummaryChecksum
|
s19l3:
|
s19l3:
|
00FFEE3F 03F swi ; get a character from input
|
00FFEEAC 08DEB9 bsr s19InputChar ; get a character from input
|
00FFEE40 001 fcb MF_INCH
|
00FFEEAE 0C101A cmpb #CTRLZ ; is it CTRL-Z?
|
00FFEE41 0C101A cmpb #CTRLZ ; is it CTRL-Z?
|
00FFEEB0 027050 beq s19l2
|
00FFEE43 02704B beq s19l2
|
00FFEEB2 07F00094B clr s19Checksum
|
00FFEE45 0C1053 cmpb #'S' ; records must start with the letter S
|
00FFEEB5 0C1043 cmpb #'C' ; records must start with the letter C
|
00FFEE47 02603A bne s19lnr
|
00FFEEB7 02603C bne s19lnr
|
00FFEE49 03F swi ; get the next character
|
00FFEEB9 08DEAC bsr s19InputChar ; get the next character
|
00FFEE4A 001 fcb MF_INCH
|
00FFEEBB 0C1030 cmpb #'0' ; must be a numeric digit
|
00FFEE4B 0C1030 cmpb #'0' ; must be a numeric digit
|
00FFEEBD 025036 blo s19lnr
|
00FFEE4D 025034 blo s19lnr
|
00FFEEBF 0C1039 cmpb #'9'
|
00FFEE4F 0C1039 cmpb #'9'
|
00FFEEC1 022032 bhi s19lnr
|
00FFEE51 022030 bhi s19lnr
|
00FFEEC3 0F7000948 stb s19Rectype ; save off in record type
|
00FFEE53 0F7000948 stb s19Rectype ; save off in record type
|
00FFEEC6 08DEDB bsr s19GetByte ; get a byte indicating record length
|
00FFEE56 08DF1D bsr s19GetByte ; get a byte indicating record length
|
00FFEEC8 08DECF bsr s19AddCheck
|
00FFEE58 0F7000949 stb s19Reclen
|
00FFEECA 0F7000949 stb s19Reclen
|
00FFEE5B 07D00094A tst s19Abort ; check for abort
|
00FFEECD 07D00094A tst s19Abort ; check for abort
|
00FFEE5E 026030 bne s19l2
|
00FFEED0 026030 bne s19l2
|
00FFEE60 0F6000948 ldb s19Rectype ; process according to record type
|
00FFEED2 0F6000948 ldb s19Rectype ; process according to record type
|
00FFEE63 0C1030 cmpb #'0'
|
00FFEED5 0C1030 cmpb #'0'
|
00FFEE65 02701C beq s19lnr
|
00FFEED7 02701C beq s19lnr
|
00FFEE67 0C1031 cmpb #'1'
|
00FFEED9 0C1031 cmpb #'1'
|
00FFEE69 027FA0 beq s19ProcessS1 ; data record with a two byte address
|
00FFEEDB 027F6C beq s19ProcessS1 ; data record with a two byte address
|
00FFEE6B 0C1032 cmpb #'2'
|
00FFEEDD 0C1032 cmpb #'2'
|
00FFEE6D 027FA2 beq s19ProcessS2 ; data record with a three byte address
|
00FFEEDF 027F7B beq s19ProcessS2 ; data record with a three byte address
|
00FFEE6F 0C1033 cmpb #'3'
|
00FFEEE1 0C1033 cmpb #'3'
|
00FFEE71 027010 beq s19lnr
|
00FFEEE3 027010 beq s19lnr
|
00FFEE73 0C1035 cmpb #'5' ; record count? ignore
|
00FFEEE5 0C1035 cmpb #'5' ; record count? ignore
|
00FFEE75 02700C beq s19lnr
|
00FFEEE7 02700C beq s19lnr
|
00FFEE77 0C1037 cmpb #'7' ; ignore record with 48 bit address
|
00FFEEE9 0C1037 cmpb #'7' ; ignore record with 48 bit address
|
00FFEE79 027015 beq s19l2
|
00FFEEEB 027015 beq s19l2
|
00FFEE7B 0C1038 cmpb #'8'
|
00FFEEED 0C1038 cmpb #'8'
|
00FFEE7D 027FA8 beq s19ProcessS8 ; two byte start address
|
00FFEEEF 027F8E beq s19ProcessS8 ; two byte start address
|
00FFEE7F 0C1039 cmpb #'9'
|
00FFEEF1 0C1039 cmpb #'9'
|
00FFEE81 027F94 beq s19ProcessS9 ; three byte start address
|
00FFEEF3 027F7A beq s19ProcessS9 ; three byte start address
|
s19lnr:
|
s19lnr:
|
00FFEE83 0C602E ldb #'.' ; output a progress indicator
|
00FFEEF5 0C602E ldb #'.' ; output a progress indicator
|
00FFEE85 03F swi
|
00FFEEF7 03F swi
|
00FFEE86 002 fcb MF_OUTCH
|
00FFEEF8 002 fcb MF_OUTCH
|
00FFEE87 08DECF bsr s19NextRecord ; skip to the next record
|
00FFEEF9 08DE84 bsr s19NextRecord ; skip to the next record
|
00FFEE89 07D00094A tst S19Abort ; check for abort
|
00FFEEFB 07D00094A tst S19Abort ; check for abort
|
00FFEE8C 026002 bne s19l2
|
00FFEEFE 026002 bne s19l2
|
00FFEE8E 020FAF bra s19l3 ; loop back to process more records
|
00FFEF00 020FAA bra s19l3 ; loop back to process more records
|
s19l2:
|
s19l2:
|
00FFEE90 0160001A6 lbra Monitor
|
00FFEF02 016000457 lbra Monitor
|
|
|
msgS19Loader:
|
msgS19Loader:
|
00FFEE93 05303103902004C06F061 fcb "S19 Loader Active",CR,LF,0
|
00FFEF05 05303103902004C06F061 fcb "S19 Loader Active",CR,LF,0
|
00FFEE9A 064065072020041063074
|
00FFEF0C 064065072020041063074
|
00FFEEA1 06907606500D00A000
|
00FFEF13 06907606500D00A000
|
|
msgChecksumErr:
|
|
00FFEF19 053031039020043068065 fcb "S19 Checksum Err",CR,LF,0
|
|
00FFEF20 06306B07307506D020045
|
|
00FFEF27 07207200D00A000
|
|
|
|
|
|
; ============================================================================
|
|
; __
|
|
; \\__/ o\ (C) 2022 Robert Finch, Waterloo
|
|
; \ __ / All rights reserved.
|
|
; \/_// robfinch@opencores.org
|
|
; ||
|
|
;
|
|
;
|
|
; BSD 3-Clause License
|
|
; Redistribution and use in source and binary forms, with or without
|
|
; modification, are permitted provided that the following conditions are met:
|
|
;
|
|
; 1. Redistributions of source code must retain the above copyright notice, this
|
|
; list of conditions and the following disclaimer.
|
|
;
|
|
; 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
; this list of conditions and the following disclaimer in the documentation
|
|
; and/or other materials provided with the distribution.
|
|
;
|
|
; 3. Neither the name of the copyright holder nor the names of its
|
|
; contributors may be used to endorse or promote products derived from
|
|
; this software without specific prior written permission.
|
|
;
|
|
; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
; AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
; IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
; DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
|
; FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
; DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
; SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
; CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
; OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
; OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
;
|
|
; ============================================================================
|
|
;
|
|
; Xmodem variables
|
|
;
|
|
xm_timer EQU $FFC020
|
|
xm_protocol EQU $9F5
|
|
xm_flag EQU $9F6
|
|
xm_checksum EQU $9F7
|
|
xm_tmp2 EQU $9F8
|
|
xm_packetnum EQU $9FA
|
|
xm_tmp EQU $9FC
|
|
xm_crc EQU $9FE
|
|
xm_ibuf EQU $A00 ; to $A7F
|
|
xm_obuf EQU $A80 ; to $AFF
|
|
|
|
; ------------------------------------------------------------------------------
|
|
; Send data using XModem.
|
|
; ------------------------------------------------------------------------------
|
|
|
|
xm_SendStart:
|
|
00FFEF2C 0170005A3 lbsr GetRange
|
|
00FFEF2F 0BE000922 ldx mon_r1+2 ; x = buffer address
|
|
00FFEF32 01F013 tfr x,u
|
|
00FFEF34 0C6001 ldb #1 ; packet numbers start at one
|
|
00FFEF36 0F70009FB stb xm_packetnum+1
|
|
; Wait for receiver to send a NAK
|
|
xm_send:
|
|
00FFEF39 0CCFFFFFF ldd #-1 ; select blocking input
|
|
00FFEF3C 03F swi
|
|
00FFEF3D 001 fcb MF_INCH
|
|
00FFEF3E 0C1015 cmpb #NAK ; should have got a NAK
|
|
00FFEF40 027004 beq xm_send5
|
|
00FFEF42 0C1043 cmpb #'C' ; or a 'C'
|
|
00FFEF44 026FF3 bne xm_send
|
|
xm_send5:
|
|
00FFEF46 0F70009F5 stb xm_protocol
|
|
xm_send4:
|
|
00FFEF49 0C6001 ldb #SOH ; send start
|
|
00FFEF4B 03F swi
|
|
00FFEF4C 1C9 fcb OUTCH
|
|
00FFEF4D 0F60009FB ldb xm_packetnum+1 ; send packet number
|
|
00FFEF50 03F swi
|
|
00FFEF51 002 fcb MF_OUTCH
|
|
00FFEF52 053 comb ; one's complement
|
|
00FFEF53 03F swi
|
|
00FFEF54 002 fcb MF_OUTCH ; send packet number complement
|
|
00FFEF55 04F clra ; acca = byte count
|
|
00FFEF56 01F013 tfr x,u ; u = buffer address
|
|
xm_send1:
|
|
00FFEF58 0E6C00 ldb ,u+ ; grab a byte from the buffer
|
|
00FFEF5A 03F swi
|
|
00FFEF5B 002 fcb MF_OUTCH ; send it out
|
|
00FFEF5C 04C inca
|
|
00FFEF5D 081080 cmpa #128 ; number of bytes in payload
|
|
00FFEF5F 025FF7 blo xm_send1
|
|
00FFEF61 0F60009F5 ldb xm_protocol
|
|
00FFEF64 0C1043 cmpb #'C' ; CRC protocol?
|
|
00FFEF66 02601E bne xm_send2
|
|
00FFEF68 08D17F bsr xm_calc_crc ; compute CRC
|
|
00FFEF6A 0FC0009FE ldd xm_crc ; get crc
|
|
00FFEF6D 044 lsra ; transfer high eight bits first, so
|
|
00FFEF6E 056 rorb ; right shift D by eight
|
|
00FFEF6F 044 lsra
|
|
00FFEF70 056 rorb
|
|
00FFEF71 044 lsra
|
|
00FFEF72 056 rorb
|
|
00FFEF73 044 lsra
|
|
00FFEF74 056 rorb
|
|
00FFEF75 044 lsra
|
|
00FFEF76 056 rorb
|
|
00FFEF77 044 lsra
|
|
00FFEF78 056 rorb
|
|
00FFEF79 044 lsra
|
|
00FFEF7A 056 rorb
|
|
00FFEF7B 044 lsra
|
|
00FFEF7C 056 rorb
|
|
00FFEF7D 03F swi
|
|
00FFEF7E 002 fcb MF_OUTCH ; send out the byte
|
|
00FFEF7F 0FC0009FE ldd xm_crc ; get back CRC
|
|
00FFEF82 03F swi
|
|
00FFEF83 002 fcb MF_OUTCH ; and send out low byte
|
|
00FFEF84 020007 bra xm_send3
|
|
xm_send2:
|
|
00FFEF86 08D14F bsr xm_calc_checksum
|
|
00FFEF88 0F60009F7 ldb xm_checksum
|
|
00FFEF8B 03F swi
|
|
00FFEF8C 002 fcb MF_OUTCH
|
|
xm_send3:
|
|
00FFEF8D 03F swi
|
|
00FFEF8E 0CCFFFFFF ldd #-1 ; block until input is present
|
|
00FFEF91 001 fcb MF_INCH
|
|
00FFEF92 0C1006 cmpb #ACK
|
|
00FFEF94 026FB3 bne xm_send4 ; not an ACK then resend the record
|
|
00FFEF96 07C0009FA inc xm_packetnum ; increment packet number
|
|
00FFEF99 030080 leax 128,x ; advance buffer pointer
|
|
00FFEF9B 0BC000926 cmpx mon_r2+2
|
|
00FFEF9E 025FA9 blo xm_send4 ; go send next record
|
|
00FFEFA0 0C6004 ldb #EOT ; send end of transmission
|
|
00FFEFA2 03F swi
|
|
00FFEFA3 002 fcb MF_OUTCH
|
|
00FFEFA4 03F swi
|
|
00FFEFA5 002 fcb MF_OUTCH
|
|
00FFEFA6 03F swi
|
|
00FFEFA7 002 fcb MF_OUTCH
|
|
00FFEFA8 039 rts
|
|
|
|
; ------------------------------------------------------------------------------
|
|
; Get a byte, checking for a receive timeout.
|
|
;
|
|
; Returns:
|
|
; accb = byte (0 to 255) or -1 if timed out
|
|
; ------------------------------------------------------------------------------
|
|
|
|
xm_getbyte:
|
|
xm_gb1:
|
|
00FFEFA9 07DFFC020 tst xm_timer ; check the timeout - 2048 ticks (3 seconds approx.)
|
|
00FFEFAC 02B009 bmi xm_gb2
|
|
00FFEFAE 04F clra ; non-blocking
|
|
00FFEFAF 05F clrb
|
|
00FFEFB0 03F swi
|
|
00FFEFB1 001 fcb MF_INCH ; try and get a character
|
|
00FFEFB2 02BFF5 bmi xm_gb1 ; if no character, try again
|
|
00FFEFB4 08D1BA bsr xm_outbyteAsHex
|
|
00FFEFB6 039 rts
|
|
xm_gb2:
|
|
00FFEFB7 0C6FFF ldb #-1
|
|
00FFEFB9 039 rts
|
|
|
|
; ------------------------------------------------------------------------------
|
|
; XModem Receive
|
|
;
|
|
; Parameters:
|
|
; none
|
|
; Modifies:
|
|
; All
|
|
; Returns:
|
|
; none
|
|
; ------------------------------------------------------------------------------
|
|
|
|
xm_ReceiveStart:
|
|
00FFEFBA 017FFF1FB lbsr Delay3s ; give a little bit of time for sender
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFEFBD 017FFF1F8 lbsr Delay3s
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFEFC0 017FFF1F5 lbsr Delay3s
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFEFC3 0170005CB lbsr GetNumber ; Get the transfer address
|
|
00FFEFC6 05D tstb ; Make sure we got a value
|
|
00FFEFC7 127000392 lbeq Monitor
|
|
00FFEFCA 0BE000912 ldx mon_numwka+2 ; X = transfer address
|
|
00FFEFCD 07F0009FA clr xm_packetnum ; initialize
|
|
00FFEFD0 086043 lda #'C' ; try for CRC first
|
|
00FFEFD2 0B70009F5 sta xm_protocol
|
|
xm_receive:
|
|
00FFEFD5 086002 lda #2 ; number of times to retry -1
|
|
xm_rcv5:
|
|
00FFEFD7 0F60009F5 ldb xm_protocol ; indicate we want a transfer (send protocol byte)
|
|
00FFEFDA 03F swi
|
|
00FFEFDB 00D fcb MF_SerialPutchar
|
|
xm_rcv4:
|
|
00FFEFDC 07FFFC020 clr xm_timer ; clear the timeout
|
|
xm_rcv1:
|
|
00FFEFDF 08DFC8 bsr xm_getbyte
|
|
00FFEFE1 05D tstb
|
|
00FFEFE2 02B0A1 bmi xm_retry1 ; timeout on protocol id?
|
|
00FFEFE4 0C1001 cmpb #SOH ; it should be start of a transfer
|
|
00FFEFE6 027012 beq xm_SOH
|
|
00FFEFE8 0C1004 cmpb #EOT
|
|
00FFEFEA 027092 beq xm_EOT ; or end of transfer (EOT)
|
|
00FFEFEC 0C1018 cmpb #CAN
|
|
00FFEFEE 027FE5 beq xm_receive ; might be a cancel
|
|
00FFEFF0 0C1017 cmpb #ETB
|
|
00FFEFF2 02708A beq xm_EOT
|
|
xm_rcv_nak: ; wasn't a valid start so
|
|
00FFEFF4 0C6015 ldb #NAK ; send a NAK
|
|
00FFEFF6 03F swi
|
|
00FFEFF7 00D fcb MF_SerialPutchar ; and try again
|
|
00FFEFF8 020FE2 bra xm_rcv4
|
|
xm_SOH:
|
|
00FFEFFA 08DFAD bsr xm_getbyte ; get packet number
|
|
00FFEFFC 02B078 bmi xm_rcv_to1
|
|
00FFEFFE 0F70009FB stb xm_packetnum+1
|
|
00FFF001 034004 pshs b ; save it
|
|
00FFF003 08DFA4 bsr xm_getbyte ; get complement of packet number
|
|
00FFF005 02B06D bmi xm_rcv_to2
|
|
00FFF007 0EBE04 addb ,s ; add the two values
|
|
00FFF009 0C40FF andb #$FF ; the sum should be $FF
|
|
00FFF00B 0C00FF subb #$FF
|
|
00FFF00D 0F70009F6 stb xm_flag ; should be storing a zero if there is no error
|
|
00FFF010 18E000000 ldy #0 ; y = payload byte counter
|
|
00FFF013 01F013 tfr x,u
|
|
xm_rcv2:
|
|
00FFF015 08DF92 bsr xm_getbyte
|
|
00FFF017 02B05D bmi xm_rcv_to1
|
|
00FFF019 0E7C00 stb ,u+ ; store the byte to memory
|
|
00FFF01B 031201 iny
|
|
00FFF01D 18C000080 cmpy #128 ; 128 bytes per payload
|
|
00FFF020 025FF3 blo xm_rcv2
|
|
00FFF022 08DF85 bsr xm_getbyte ; get checksum or CRC byte
|
|
00FFF024 02B050 bmi xm_rcv_to1
|
|
00FFF026 0F70009FC stb xm_tmp ; stuff checksum/CRC byte
|
|
00FFF029 0F60009F5 ldb xm_protocol
|
|
00FFF02C 0C1043 cmpb #'C'
|
|
00FFF02E 026022 bne xm_rcv_chksum
|
|
00FFF030 08DF77 bsr xm_getbyte ; get low order CRC byte
|
|
00FFF032 02B042 bmi xm_rcv_to1
|
|
00FFF034 0B60009FC lda xm_tmp ; get the high byte
|
|
00FFF037 058 aslb ; prepare to combine high and low order
|
|
00FFF038 058 aslb
|
|
00FFF039 058 aslb
|
|
00FFF03A 058 aslb
|
|
00FFF03B 044 lsra ; shift low nybble of acca into accb
|
|
00FFF03C 056 rorb
|
|
00FFF03D 044 lsra
|
|
00FFF03E 056 rorb
|
|
00FFF03F 044 lsra
|
|
00FFF040 056 rorb
|
|
00FFF041 044 lsra
|
|
00FFF042 056 rorb
|
|
00FFF043 08400F anda #$00F ; mask off any extra bits
|
|
00FFF045 0FD0009F8 std xm_tmp2
|
|
00FFF048 08D09F bsr xm_calc_crc ; compute the CRC-16 for the received data
|
|
00FFF04A 0FC0009FE ldd xm_crc ; and compare to received value
|
|
00FFF04D 1B30009F8 cmpd xm_tmp2
|
|
00FFF050 020008 bra xm_rcv3
|
|
xm_rcv_chksum:
|
|
00FFF052 08D083 bsr xm_calc_checksum
|
|
00FFF054 0F60009F7 ldb xm_checksum
|
|
00FFF057 0F10009FC cmpb xm_tmp ; where we stuffed the byte
|
|
xm_rcv3:
|
|
00FFF05A 026F98 bne xm_rcv_nak ; if not the same, NAK
|
|
00FFF05C 07D0009F6 tst xm_flag
|
|
00FFF05F 026F93 bne xm_rcv_nak ; bad packet number?
|
|
00FFF061 0C6006 ldb #ACK ; packet recieved okay, send back an ACK
|
|
00FFF063 03F swi
|
|
00FFF064 00D fcb MF_SerialPutchar
|
|
00FFF065 0F60009FB ldb xm_packetnum+1 ; did we receive the same packet
|
|
00FFF068 0F10009FA cmpb xm_packetnum
|
|
00FFF06B 027F6F beq xm_rcv4 ; same packet received, dont update buffer pointer
|
|
00FFF06D 0F70009FA stb xm_packetnum ; update last seen packet number
|
|
00FFF070 030080 leax 128,x ; increment buffer pointer
|
|
00FFF072 020F68 bra xm_rcv4 ; and go back for next packet
|
|
xm_rcv_to2:
|
|
00FFF074 032601 leas 1,s ; get rid of stacked byte
|
|
xm_rcv_to1:
|
|
00FFF076 0CCFFF09E ldd #msgXmTimeout
|
|
00FFF079 03F swi
|
|
00FFF07A 004 fcb MF_DisplayString
|
|
00FFF07B 0160002DE lbra Monitor
|
|
xm_EOT: ; end of transmission received, return
|
|
00FFF07E 0C6006 ldb #ACK ; ACK the EOT
|
|
00FFF080 03F swi
|
|
00FFF081 00D fcb MF_SerialPutchar
|
|
00FFF082 0160002D7 lbra Monitor
|
|
xm_retry1:
|
|
00FFF085 04A deca
|
|
00FFF086 02AF4F bpl xm_rcv5
|
|
00FFF088 0B60009F5 lda xm_protocol
|
|
00FFF08B 081015 cmpa #NAK ; are we already lowered down to checksum protocol?
|
|
00FFF08D 027007 beq xm_noTransmitter ; did we try both checksum and CRC?
|
|
00FFF08F 086015 lda #NAK
|
|
00FFF091 0B70009F5 sta xm_protocol
|
|
00FFF094 020F3F bra xm_receive
|
|
xm_noTransmitter:
|
|
00FFF096 0CCFFF0B2 ldd #msgXmNoTransmitter
|
|
00FFF099 03F swi
|
|
00FFF09A 004 fcb MF_DisplayString
|
|
00FFF09B 0160002BE lbra Monitor
|
|
|
|
msgXmTimeout:
|
|
00FFF09E 05806D06F06406506D03A fcb "Xmodem: timed out",CR,LF,0
|
|
00FFF0A5 02007406906D065064020
|
|
00FFF0AC 06F07507400D00A000
|
|
msgXmNoTransmitter:
|
|
00FFF0B2 05804D06F06406506D03A fcb "XModem: transmitter not responding",CR,LF,0
|
|
00FFF0B9 02007407206106E07306D
|
|
00FFF0C0 06907407406507202006E
|
|
00FFF0C7 06F074020072065073070
|
|
00FFF0CE 06F06E06406906E06700D
|
|
00FFF0D5 00A000
|
|
|
|
; ------------------------------------------------------------------------------
|
|
; Calculate checksum value. The checksum is simply the low order eight bits of
|
|
; the sum of all the bytes in the payload area.
|
|
;
|
|
; Stack space:
|
|
; two words
|
|
; Modifies:
|
|
; xm_checksum contains the checksum value for the record
|
|
; Parameters:
|
|
; X = buffer address
|
|
; Returns:
|
|
; none
|
|
; ------------------------------------------------------------------------------
|
|
|
|
xm_calc_checksum:
|
|
00FFF0D7 034016 pshs d,x
|
|
00FFF0D9 04F clra
|
|
00FFF0DA 05F clrb
|
|
xm_cs1:
|
|
00FFF0DB 0EB800 addb ,x+
|
|
00FFF0DD 04C inca
|
|
00FFF0DE 081080 cmpa #128
|
|
00FFF0E0 025FF9 blo xm_cs1
|
|
00FFF0E2 0C40FF andb #$FF
|
|
00FFF0E4 0F70009F7 stb xm_checksum
|
|
00FFF0E7 035096 puls d,x,pc
|
|
|
|
; ------------------------------------------------------------------------------
|
|
; Compute CRC-16 of buffer.
|
|
;
|
|
;int calcrc(char *ptr, int count)
|
|
;{
|
|
; int crc;
|
|
; char i;
|
|
; crc = 0;
|
|
; while (--count >= 0)
|
|
; {
|
|
; crc = crc ^ (int) (*ptr++ << 8);
|
|
; i = 8;
|
|
; do
|
|
; {
|
|
; if (crc & 0x8000)
|
|
; crc = crc << 1 ^ 0x1021;
|
|
; else
|
|
; crc = crc << 1;
|
|
; } while(--i);
|
|
; }
|
|
; return (crc);
|
|
;}
|
|
;
|
|
; Modifies:
|
|
; xm_crc variable
|
|
; Parameters:
|
|
; u = buffer address
|
|
; Returns:
|
|
; none
|
|
; ------------------------------------------------------------------------------
|
|
|
|
xm_calc_crc:
|
|
00FFF0E9 034076 pshs d,x,y,u
|
|
00FFF0EB 07F0009FE clr xm_crc
|
|
00FFF0EE 07F0009FF clr xm_crc+1
|
|
00FFF0F1 0CE000000 ldu #0 ; u = byte count
|
|
xm_crc1:
|
|
00FFF0F4 0E6800 ldb ,x+ ; get byte
|
|
00FFF0F6 07F0009FC clr xm_tmp ; save in temp
|
|
00FFF0F9 0F70009FD stb xm_tmp+1
|
|
00FFF0FC 0780009FD asl xm_tmp+1 ; shift temp eight bits to left
|
|
00FFF0FF 0790009FC rol xm_tmp
|
|
00FFF102 0780009FD asl xm_tmp+1
|
|
00FFF105 0790009FC rol xm_tmp
|
|
00FFF108 0780009FD asl xm_tmp+1
|
|
00FFF10B 0790009FC rol xm_tmp
|
|
00FFF10E 0780009FD asl xm_tmp+1
|
|
00FFF111 0790009FC rol xm_tmp
|
|
00FFF114 0780009FD asl xm_tmp+1
|
|
00FFF117 0790009FC rol xm_tmp
|
|
00FFF11A 0780009FD asl xm_tmp+1
|
|
00FFF11D 0790009FC rol xm_tmp
|
|
00FFF120 0780009FD asl xm_tmp+1
|
|
00FFF123 0790009FC rol xm_tmp
|
|
00FFF126 0780009FD asl xm_tmp+1
|
|
00FFF129 0790009FC rol xm_tmp
|
|
00FFF12C 0FC0009FE ldd xm_crc ; crc = crc ^ tmp
|
|
00FFF12F 0B80009FC eora xm_tmp
|
|
00FFF132 0F80009FD eorb xm_tmp+1
|
|
00FFF135 0FD0009FE std xm_crc
|
|
00FFF138 18E000000 ldy #0
|
|
xm_crc4:
|
|
00FFF13B 0F60009FE ldb xm_crc ; get high byte
|
|
00FFF13E 0C5008 bitb #$8 ; check for $8000
|
|
00FFF140 02700E beq xm_crc2 ; no? then just go shift
|
|
00FFF142 0FC0009FE ldd xm_crc ; load
|
|
00FFF145 058 aslb ; shift
|
|
00FFF146 049 rola
|
|
00FFF147 0C8021 eorb #$021 ; and xor
|
|
00FFF149 088001 eora #$001
|
|
00FFF14B 0FD0009FE std xm_crc ; store it back
|
|
00FFF14E 020008 bra xm_crc3
|
|
xm_crc2:
|
|
00FFF150 0FC0009FE ldd xm_crc ; load
|
|
00FFF153 058 aslb ; shift
|
|
00FFF154 049 rola
|
|
00FFF155 0FD0009FE std xm_crc ; and store
|
|
xm_crc3:
|
|
00FFF158 031201 iny
|
|
00FFF15A 18C000008 cmpy #8 ; repeat eight times
|
|
00FFF15D 025FDC blo xm_crc4
|
|
00FFF15F 033401 leau 1,u ; increment byte count
|
|
00FFF161 283000080 cmpu #128
|
|
00FFF164 0FC0009FE ldd xm_crc ; we want only a 16-bit CRC
|
|
00FFF167 08400F anda #$0F
|
|
00FFF169 0FD0009FE std xm_crc
|
|
00FFF16C 025F86 blo xm_crc1
|
|
00FFF16E 0350F6 puls d,x,y,u,pc
|
|
|
|
xm_outbyteAsHex:
|
|
00FFF170 034006 pshs d
|
|
00FFF172 0FC000800 ldd CharOutVec ; get current char out vector
|
|
00FFF175 034006 pshs d ; save it
|
|
00FFF177 0CCFFE31F ldd #ScreenDisplayChar ; set output vector to screen display
|
|
00FFF17A 0FD000800 std CharOUtVec
|
|
00FFF17D 0EC602 ldd 2,s ; get passed data
|
|
00FFF17F 017FFF2B8 lbsr DispByteAsHex ; and display on-screen
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF182 0C6020 ldb #' '
|
|
00FFF184 017FFF198 lbsr ScreenDisplayChar
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF187 035006 puls d ; get back old char out vector
|
|
00FFF189 0FD000800 std CharOutVec ; and restore it
|
|
00FFF18C 035006 puls d ; restore input arguments
|
|
00FFF18E 039 rts
|
|
|
|
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Check if there is a keyboard character available. If so return true (<0)
|
; Check if there is a keyboard character available. If so return true (<0)
|
; otherwise return false (0) in accb.
|
; otherwise return false (0) in accb.
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
KeybdCheckForKeyDirect:
|
KeybdCheckForKeyDirect:
|
00FFEEA7 020BE7 bra DBGCheckForKey
|
00FFF18F 0208FF bra DBGCheckForKey
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
INCH:
|
INCH:
|
00FFEEA9 034004 pshs b
|
00FFF191 034004 pshs b
|
INCH2:
|
INCH2:
|
00FFEEAB 0150F6FFFFFFFE0 ldb COREID
|
00FFF193 0150F6FFFFFFFE0 ldb COREID
|
00FFEEB0 0F1FFC010 cmpb IOFocusID ; if we do not have focus, block
|
00FFF198 0F1FFC010 cmpb IOFocusID ; if we do not have focus, block
|
00FFEEB3 026FF6 bne INCH2
|
00FFF19B 026FF6 bne INCH2
|
; ldb #$800 ; block if no key available, get scancode directly
|
; ldb #$800 ; block if no key available, get scancode directly
|
; bra GetKey
|
; bra GetKey
|
; jsr [CharInVec] ; vector is being overwritten somehow
|
; jsr [CharInVec] ; vector is being overwritten somehow
|
00FFEEB5 017FFFDAC lbsr SerialPeekCharDirect
|
00FFF19D 017FFFAD3 lbsr SerialPeekCharDirect
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFEEB8 04D tsta
|
; lbsr SerialGetChar
|
00FFEEB9 02B003 bmi INCH1 ; block if no key available
|
00FFF1A0 04D tsta
|
00FFEEBB 032601 leas 1,s ; get rid of blocking status
|
00FFF1A1 02B003 bmi INCH1 ; block if no key available
|
00FFEEBD 039 rts
|
00FFF1A3 032601 leas 1,s ; get rid of blocking status
|
|
00FFF1A5 039 rts ; return character
|
INCH1:
|
INCH1:
|
00FFEEBE 035004 puls b ; check blocking status
|
00FFF1A6 035004 puls b ; check blocking status
|
00FFEEC0 05D tstb
|
00FFF1A8 05D tstb
|
00FFEEC1 02BFE6 bmi INCH ; if blocking, loop
|
00FFF1A9 02BFE6 bmi INCH ; if blocking, loop
|
00FFEEC3 0CCFFFFFF ldd #-1 ; return -1 if no char available
|
00FFF1AB 0CCFFFFFF ldd #-1 ; return -1 if no char available
|
00FFEEC6 039 rts
|
00FFF1AE 039 rts
|
|
|
INCHE:
|
INCHE:
|
00FFEEC7 08DFE0 bsr INCH
|
00FFF1AF 08DFE0 bsr INCH
|
00FFEEC9 020009 bra INCHEK3
|
00FFF1B1 020009 bra INCHEK3
|
|
|
INCHEK:
|
INCHEK:
|
00FFEECB 08DFDC bsr INCH
|
00FFF1B3 08DFDC bsr INCH
|
00FFEECD 01507DFFFFFCA00 tst KeybdEcho
|
00FFF1B5 01507DFFFFFCA00 tst KeybdEcho
|
00FFEED2 02700C beq INCHEK1
|
00FFF1BA 02700C beq INCHEK1
|
INCHEK3:
|
INCHEK3:
|
00FFEED4 08100D cmpa #CR
|
00FFF1BC 08100D cmpa #CR
|
00FFEED6 026005 bne INCHEK2
|
00FFF1BE 026005 bne INCHEK2
|
00FFEED8 017FFE1F7 lbsr CRLF
|
00FFF1C0 017FFDF0F lbsr CRLF
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFEEDB 020003 bra INCHEK1
|
00FFF1C3 020003 bra INCHEK1
|
INCHEK2:
|
INCHEK2:
|
00FFEEDD 017FFF439 lbsr DisplayChar
|
00FFF1C5 017FFF154 lbsr DisplayChar
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
INCHEK1:
|
INCHEK1:
|
00FFEEE0 039 rts
|
00FFF1C8 039 rts
|
|
|
OUTCH:
|
OUTCH:
|
00FFEEE1 06E90F000800 jmp [CharOutVec]
|
00FFF1C9 06E90F000800 jmp [CharOutVec]
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; r1 0=echo off, non-zero = echo on
|
; r1 0=echo off, non-zero = echo on
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
SetKeyboardEcho:
|
SetKeyboardEcho:
|
00FFEEE5 0150F7FFFFFCA00 stb KeybdEcho
|
00FFF1CD 0150F7FFFFFCA00 stb KeybdEcho
|
00FFEEEA 039 rts
|
00FFF1D2 039 rts
|
|
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Parameters:
|
; Parameters:
|
; x,d bitmap of sprites to enable
|
; x,d bitmap of sprites to enable
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
ShowSprites:
|
ShowSprites:
|
00FFEEEB 0150BFFFFE103C0 stx SPRITE_CTRL+SPRITE_EN
|
00FFF1D3 0150BFFFFE103C0 stx SPRITE_CTRL+SPRITE_EN
|
00FFEEF0 0150FDFFFE103C2 std SPRITE_CTRL+SPRITE_EN+2
|
00FFF1D8 0150FDFFFE103C2 std SPRITE_CTRL+SPRITE_EN+2
|
00FFEEF5 039 rts
|
00FFF1DD 039 rts
|
|
|
;==============================================================================
|
;==============================================================================
|
; Femtiki Operating System.
|
; Femtiki Operating System.
|
;==============================================================================
|
;==============================================================================
|
|
|
OSCallTbl:
|
OSCallTbl:
|
00FFEEF6 000000 fcw 0
|
00FFF1DE 000000 fcw 0
|
00FFEEF8 000000 fcw 0
|
00FFF1E0 000000 fcw 0
|
00FFEEFA 000000 fcw 0
|
00FFF1E2 000000 fcw 0
|
00FFEEFC 000000 fcw 0
|
00FFF1E4 000000 fcw 0
|
00FFEEFE 000000 fcw 0
|
00FFF1E6 000000 fcw 0
|
00FFEF00 000000 fcw 0
|
00FFF1E8 000000 fcw 0
|
00FFEF02 000000 fcw 0
|
00FFF1EA 000000 fcw 0
|
00FFEF04 000000 fcw 0
|
00FFF1EC 000000 fcw 0
|
00FFEF06 000000 fcw 0
|
00FFF1EE 000000 fcw 0
|
00FFEF08 000000 fcw 0
|
00FFF1F0 000000 fcw 0
|
00FFEF0A 000000 fcw 0
|
00FFF1F2 000000 fcw 0
|
00FFEF0C 000000 fcw 0
|
00FFF1F4 000000 fcw 0
|
00FFEF0E 000000 fcw 0
|
00FFF1F6 000000 fcw 0
|
00FFEF10 000000 fcw 0
|
00FFF1F8 000000 fcw 0
|
00FFEF12 000000 fcw 0
|
00FFF1FA 000000 fcw 0
|
00FFEF14 000000 fcw 0
|
00FFF1FC 000000 fcw 0
|
00FFEF16 000000 fcw 0
|
00FFF1FE 000000 fcw 0
|
00FFEF18 000000 fcw 0
|
00FFF200 000000 fcw 0
|
00FFEF1A 000000 fcw 0
|
00FFF202 000000 fcw 0
|
00FFEF1C 000000 fcw 0
|
00FFF204 000000 fcw 0
|
00FFEF1E 000000 fcw 0
|
00FFF206 000000 fcw 0
|
00FFEF20 000000 fcw 0
|
00FFF208 000000 fcw 0
|
00FFEF22 FFEF3F fcw ReleaseIOFocus
|
00FFF20A FFF227 fcw ReleaseIOFocus
|
00FFEF24 000000 fcw 0
|
00FFF20C 000000 fcw 0
|
00FFEF26 FFEF28 fcw RequestIOFocus
|
00FFF20E FFF210 fcw RequestIOFocus
|
|
|
NumOSFuncs EQU (*-OSCallTbl)/2
|
NumOSFuncs EQU (*-OSCallTbl)/2
|
|
|
RequestIOFocus:
|
RequestIOFocus:
|
00FFEF28 0150F6FFFFFFFE0 ldb COREID
|
00FFF210 0150F6FFFFFFFE0 ldb COREID
|
00FFEF2D 08EFFC000 ldx #IOFocusList
|
00FFF215 08EFFC000 ldx #IOFocusList
|
00FFEF30 03A abx
|
00FFF218 03A abx
|
00FFEF31 0A7804 sta ,x
|
00FFF219 0A7804 sta ,x
|
00FFEF33 07DFFC010 tst IOFocusID
|
00FFF21B 07DFFC010 tst IOFocusID
|
00FFEF36 1260007D1 lbne oscx
|
00FFF21E 1260008DC lbne oscx
|
00FFEF39 0F7FFC010 stb IOFocusID
|
00FFF221 0F7FFC010 stb IOFocusID
|
00FFEF3C 0160007CB lbra oscx
|
00FFF224 0160008D6 lbra oscx
|
|
|
ReleaseIOFocus:
|
ReleaseIOFocus:
|
00FFEF3F 0150F6FFFFFFFE0 ldb COREID
|
00FFF227 0150F6FFFFFFFE0 ldb COREID
|
00FFEF44 08EFFC000 ldx #IOFocusList
|
00FFF22C 08EFFC000 ldx #IOFocusList
|
00FFEF47 03A abx
|
00FFF22F 03A abx
|
00FFEF48 06F804 clr ,x ; clear the request indicator
|
00FFF230 06F804 clr ,x ; clear the request indicator
|
00FFEF4A 017FFF2BC lbsr CopyScreenToVirtualScreen
|
00FFF232 017FFEFD7 lbsr CopyScreenToVirtualScreen
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFEF4D 0F1FFC010 cmpb IOFocusID ; are we the one with the focus?
|
00FFF235 0F1FFC010 cmpb IOFocusID ; are we the one with the focus?
|
00FFEF50 1260007B7 lbne oscx
|
00FFF238 1260008C2 lbne oscx
|
; We had the focus, so now a new core needs the focus.
|
; We had the focus, so now a new core needs the focus.
|
; Search the focus list for a requestor. If no requester
|
; Search the focus list for a requestor. If no requester
|
; is found, give focus to core #1.
|
; is found, give focus to core #1.
|
00FFEF53 08600F lda #15
|
00FFF23B 08600F lda #15
|
riof2:
|
riof2:
|
00FFEF55 05C incb
|
00FFF23D 05C incb
|
00FFEF56 0C400F andb #15
|
00FFF23E 0C400F andb #15
|
00FFEF58 03A abx
|
00FFF240 03A abx
|
00FFEF59 06D804 tst ,x
|
00FFF241 06D804 tst ,x
|
00FFEF5B 026009 bne riof1
|
00FFF243 026009 bne riof1
|
00FFEF5D 04A deca
|
00FFF245 04A deca
|
00FFEF5E 026FF5 bne riof2
|
00FFF246 026FF5 bne riof2
|
; If no focus is requested by anyone, give to core #1
|
; If no focus is requested by anyone, give to core #1
|
00FFEF60 0C6001 ldb #1
|
00FFF248 0C6001 ldb #1
|
00FFEF62 086018 lda #24
|
00FFF24A 086018 lda #24
|
00FFEF64 0A7804 sta ,x
|
00FFF24C 0A7804 sta ,x
|
riof1:
|
riof1:
|
00FFEF66 0F7FFC010 stb IOFocusID
|
00FFF24E 0F7FFC010 stb IOFocusID
|
00FFEF69 017FFF266 lbsr CopyVirtualScreenToScreen
|
00FFF251 017FFEF81 lbsr CopyVirtualScreenToScreen
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFEF6C 01600079B lbra oscx
|
00FFF254 0160008A6 lbra oscx
|
|
|
|
|
;==============================================================================
|
;==============================================================================
|
;==============================================================================
|
;==============================================================================
|
|
|
Line 3194... |
Line 3758... |
; Returns:
|
; Returns:
|
; none
|
; none
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
mon_srand:
|
mon_srand:
|
00FFEF6F 18E000000 ldy #0
|
00FFF257 18E000000 ldy #0
|
mon_srand1:
|
mon_srand1:
|
00FFEF72 0151BFFFFE30604 sty PRNG+4 ; select channel
|
00FFF25A 0151BFFFFE30604 sty PRNG+4 ; select channel
|
00FFEF77 01507FFFFE30608 clr PRNG+8
|
00FFF25F 01507FFFFE30608 clr PRNG+8
|
00FFEF7C 01507FFFFE30609 clr PRNG+9
|
00FFF264 01507FFFFE30609 clr PRNG+9
|
00FFEF81 0150FDFFFE3060A std PRNG+10 ; update low half of value
|
00FFF269 0150FDFFFE3060A std PRNG+10 ; update low half of value
|
00FFEF86 01507FFFFE3060C clr PRNG+12
|
00FFF26E 01507FFFFE3060C clr PRNG+12
|
00FFEF8B 01507FFFFE3060D clr PRNG+13
|
00FFF273 01507FFFFE3060D clr PRNG+13
|
00FFEF90 0150BFFFFE3060E stx PRNG+14 ; update low half of value
|
00FFF278 0150BFFFFE3060E stx PRNG+14 ; update low half of value
|
00FFEF95 031201 iny
|
00FFF27D 031201 iny
|
00FFEF97 18C000400 cmpy #$400 ; 1k channels
|
00FFF27F 18C000400 cmpy #$400 ; 1k channels
|
00FFEF9A 025FD6 blo mon_srand1
|
00FFF282 025FD6 blo mon_srand1
|
00FFEF9C 039 rts
|
00FFF284 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Get a random number and generate the next one.
|
; Get a random number and generate the next one.
|
;
|
;
|
; Parameters:
|
; Parameters:
|
Line 3218... |
Line 3782... |
; Returns:
|
; Returns:
|
; x,d = 36 bit random value
|
; x,d = 36 bit random value
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
mon_rand:
|
mon_rand:
|
00FFEF9D 0150FDFFFE30604 std PRNG+4 ; select channel
|
00FFF285 0150FDFFFE30604 std PRNG+4 ; select channel
|
00FFEFA2 0150BEFFFE30600 ldx PRNG+0
|
00FFF28A 0150BEFFFE30600 ldx PRNG+0
|
00FFEFA7 0150FCFFFE30602 ldd PRNG+2
|
00FFF28F 0150FCFFFE30602 ldd PRNG+2
|
00FFEFAC 0150F7FFFE30603 stb PRNG+3 ; trigger calc of next number
|
00FFF294 0150F7FFFE30603 stb PRNG+3 ; trigger calc of next number
|
00FFEFB1 039 rts
|
00FFF299 039 rts
|
|
|
;==============================================================================
|
;==============================================================================
|
; System Monitor
|
; System Monitor
|
;==============================================================================
|
;==============================================================================
|
|
|
; Command Tables
|
; Command Tables
|
|
|
cmdTable1:
|
cmdTable1:
|
00FFEFB2 03C83E fcb '<','>'+$800
|
00FFF29A 03C83E fcb '<','>'+$800
|
00FFEFB4 062873 fcb 'b','s'+$800
|
00FFF29C 04282B fcb 'B','+'+$800
|
00FFEFB6 062863 fcb 'b','c'+$800
|
00FFF29E 04282D fcb 'B','-'+$800
|
00FFEFB8 044852 fcb 'D','R'+$800
|
00FFF2A0 044852 fcb 'D','R'+$800
|
00FFEFBA 844 fcb 'D'+$800
|
00FFF2A2 844 fcb 'D'+$800
|
00FFEFBB 83A fcb ':'+$800
|
00FFF2A3 83A fcb ':'+$800
|
00FFEFBC 046049847 fcb "FI",'G'+$800
|
00FFF2A4 046049847 fcb "FI",'G'+$800
|
00FFEFBF 04604984C fcb "FI",'L'+$800
|
00FFF2A7 04604984C fcb "FI",'L'+$800
|
00FFEFC2 04684C fcb 'F','L'+$800
|
00FFF2AA 04684C fcb 'F','L'+$800
|
00FFEFC4 84A fcb 'J'+$800
|
00FFF2AC 84A fcb 'J'+$800
|
00FFEFC5 05204104D054045053854 fcb "RAMTES",'T'+$800
|
00FFF2AD 05204104D054045053854 fcb "RAMTES",'T'+$800
|
00FFEFCC 053050844 fcb "SP",'D'+$800
|
00FFF2B4 053050844 fcb "SP",'D'+$800
|
00FFEFCF 054049852 fcb "TI",'R'+$800
|
00FFF2B7 054049852 fcb "TI",'R'+$800
|
00FFEFD2 855 fcb 'U'+$800
|
00FFF2BA 855 fcb 'U'+$800
|
00FFEFD3 065078069874 fcb "exi",'t'+$800
|
00FFF2BB 065078069874 fcb "exi",'t'+$800
|
00FFEFD7 83F fcb '?'+$800
|
00FFF2BF 83F fcb '?'+$800
|
00FFEFD8 04304C853 fcb "CL",'S'+$800
|
00FFF2C0 04304C853 fcb "CL",'S'+$800
|
00FFEFDB 053031839 fcb "S1",'9'+$800
|
00FFF2C3 053031839 fcb "S1",'9'+$800
|
00FFEFDE 04A044834 fcb "JD",'4'+$800
|
00FFF2C6 04A044834 fcb "JD",'4'+$800
|
00FFEFE1 000000 fcw 0
|
00FFF2C9 05804D852 fcb "XM",'R'+$800
|
|
00FFF2CC 05804D853 fcb "XM",'S'+$800
|
|
00FFF2CF 052841 fcb 'R','A'+$800
|
|
00FFF2D1 052842 fcb 'R','B'+$800
|
|
00FFF2D3 052044050852 fcb "RDP",'R'+$800
|
|
00FFF2D7 052844 fcb 'R','D'+$800
|
|
00FFF2D9 052858 fcb 'R','X'+$800
|
|
00FFF2DB 052859 fcb 'R','Y'+$800
|
|
00FFF2DD 052855 fcb 'R','U'+$800
|
|
00FFF2DF 052853 fcb 'R','S'+$800
|
|
00FFF2E1 052043043852 fcb "RCC",'R'+$800
|
|
00FFF2E5 052050843 fcb "RP",'C'+$800
|
|
00FFF2E8 04C842 fcb 'L','B'+$800
|
|
00FFF2EA 000000 fcw 0
|
|
|
cmdTable2:
|
cmdTable2:
|
00FFEFE3 FFF0F8 fcw Redirect
|
00FFF2EC FFF427 fcw Redirect
|
00FFEFE5 FFF13A fcw MonArmBreakpoint
|
00FFF2EE FFF469 fcw MonArmBreakpoint
|
00FFEFE7 FFF145 fcw MonDisarmBreakpoint
|
00FFF2F0 FFF474 fcw MonDisarmBreakpoint
|
00FFEFE9 FFF54A fcw DumpRegs
|
00FFF2F2 FFF899 fcw DumpRegs
|
00FFEFEB FFF484 fcw DumpMemory
|
00FFF2F4 FFF7D0 fcw DumpMemory
|
00FFEFED FFF4E0 fcw EditMemory
|
00FFF2F6 FFF82C fcw EditMemory
|
00FFEFEF FE0000 fcw $FE0000 ; FIG forth
|
00FFF2F8 FE0000 fcw $FE0000 ; FIG forth
|
00FFEFF1 FFF520 fcw FillMemory
|
00FFF2FA FFF86F fcw FillMemory
|
00FFEFF3 FFF60B fcw DumpIOFocusList
|
00FFF2FC FFF9F5 fcw DumpIOFocusList
|
00FFEFF5 FFF595 fcw jump_to_code
|
00FFF2FE FFF980 fcw jump_to_code
|
00FFEFF7 FFD400 fcw $FFD400
|
00FFF300 FFD400 fcw $FFD400
|
00FFEFF9 FF8000 fcw $FF8000 ; sprite demo
|
00FFF302 FF8000 fcw $FF8000 ; sprite demo
|
00FFEFFB FFE4F4 fcw rtc_read
|
00FFF304 FFE524 fcw rtc_read
|
00FFEFFD FF8003 fcw $FF8003 ; unassembler
|
00FFF306 FF8003 fcw $FF8003 ; unassembler
|
00FFEFFF FFF6F3 fcw xitMonitor
|
00FFF308 FFFAE6 fcw xitMonitor
|
00FFF001 FFF11E fcw PromptHelp
|
00FFF30A FFF44D fcw PromptHelp
|
00FFF003 FFF126 fcw PromptClearscreen
|
00FFF30C FFF455 fcw PromptClearscreen
|
00FFF005 FFEE37 fcw S19Loader
|
00FFF30E FFEE8F fcw S19Loader
|
00FFF007 FFD400 fcw $FFD400
|
00FFF310 FFD400 fcw $FFD400
|
|
00FFF312 FFEFBA fcw xm_ReceiveStart
|
|
00FFF314 FFEF2C fcw xm_SendStart
|
|
00FFF316 FFF8E4 fcw SetRegA
|
|
00FFF318 FFF8F3 fcw SetRegB
|
|
00FFF31A FFF94D fcw SetRegDPR
|
|
00FFF31C FFF902 fcw SetRegD
|
|
00FFF31E FFF911 fcw SetRegX
|
|
00FFF320 FFF920 fcw SetRegY
|
|
00FFF322 FFF92F fcw SetRegU
|
|
00FFF324 FFF93E fcw SetRegS
|
|
00FFF326 FFF95C fcw SetRegCCR
|
|
00FFF328 FFF96B fcw SetRegPC
|
|
00FFF32A FFFBD2 fcw ListBreakpoints
|
|
|
CmdPrompt:
|
CmdPrompt:
|
00FFF009 017FFE0C6 lbsr CRLF
|
00FFF32C 017FFDDA3 lbsr CRLF
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF00C 0C6024 ldb #'$'
|
00FFF32F 0C6024 ldb #'$'
|
00FFF00E 017FFFED0 lbsr OUTCH
|
00FFF331 017FFFE95 lbsr OUTCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF011 016FFFECD lbra OUTCH
|
00FFF334 016FFFE92 lbra OUTCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
msgF09Starting:
|
msgF09Starting:
|
00FFF014 04606506D07406906B069 fcb "Femtiki F09 Multi-core OS Starting",CR,LF,0
|
00FFF337 04606506D07406906B069 fcb "Femtiki F09 Multi-core OS Starting",CR,LF,0
|
00FFF01B 02004603003902004D075
|
00FFF33E 02004603003902004D075
|
00FFF022 06C07406902D06306F072
|
00FFF345 06C07406902D06306F072
|
00FFF029 06502004F053020053074
|
00FFF34C 06502004F053020053074
|
00FFF030 06107207406906E06700D
|
00FFF353 06107207406906E06700D
|
00FFF037 00A000
|
00FFF35A 00A000
|
|
|
Monitor:
|
Monitor:
|
00FFF039 0FC00092C ldd mon_init ; check special code to see if monitor has been initialized
|
00FFF35C 01C0EF andcc #$EF ; SWI disables interrupts, re-enable them
|
00FFF03C 18312D687 cmpd #1234567
|
00FFF35E 08601F lda #31 ; Timer is IRQ #31
|
00FFF03F 02704D beq mon1
|
00FFF360 0150B7FFFE3F010 sta PIC+16 ; register 16 is edge sense reset reg
|
00FFF041 07F000810 clr BreakpointFlag
|
00FFF365 0FC00092C ldd mon_init ; check special code to see if monitor has been initialized
|
00FFF044 07F000811 clr NumSetBreakpoints
|
00FFF368 18312D687 cmpd #1234567
|
00FFF047 0CC00007B ldd #123
|
00FFF36B 02704D beq mon1
|
00FFF04A 08E00028E ldx #654
|
00FFF36D 07F000810 clr BreakpointFlag
|
00FFF04D 017FFFF1F lbsr mon_srand
|
00FFF370 07F000811 clr NumSetBreakpoints
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF373 0CC00007B ldd #123
|
00FFF050 0CCFFF014 ldd #msgF09Starting
|
00FFF376 08E00028E ldx #654
|
00FFF053 017FFF384 lbsr DisplayString
|
00FFF379 017FFFEDB lbsr mon_srand
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF056 0CCFFF2CF ldd #HelpMsg
|
00FFF37C 0CCFFF337 ldd #msgF09Starting
|
00FFF059 017FFF37E lbsr DisplayString
|
00FFF37F 017FFF05B lbsr DisplayString
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF05C 0CCFFF009 ldd #CmdPrompt
|
00FFF382 0CCFFF5FE ldd #HelpMsg
|
00FFF05F 0FD000808 std CmdPromptJI
|
00FFF385 017FFF055 lbsr DisplayString
|
00FFF062 0CCFFF2B6 ldd #DisplayErr
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF065 0FD00080C std MonErrVec
|
00FFF388 0CCFFF32C ldd #CmdPrompt
|
00FFF068 0CC0063FF ldd #$63FF ; default app stack
|
00FFF38B 0FD000808 std CmdPromptJI
|
00FFF06B 0FD000908 std mon_SSAVE
|
00FFF38E 0CCFFF5E5 ldd #DisplayErr
|
00FFF06E 07F00090E clr mon_DPRSAVE ;
|
00FFF391 0FD00080C std MonErrVec
|
00FFF071 01F0A8 tfr ccr,a
|
00FFF394 0CC0063FF ldd #$63FF ; default app stack
|
00FFF073 0B700090F sta mon_CCRSAVE
|
00FFF397 0FD000908 std mon_SSAVE
|
00FFF076 07F00090A clr mon_PCSAVE
|
00FFF39A 07F00090E clr mon_DPRSAVE ;
|
00FFF079 0CCFFF039 ldd #Monitor
|
00FFF39D 01F0A8 tfr ccr,a
|
00FFF07C 0FD00090B std mon_PCSAVE+1
|
00FFF39F 0B700090F sta mon_CCRSAVE
|
00FFF07F 07F000902 clr mon_XSAVE
|
00FFF3A2 07F00090A clr mon_PCSAVE
|
00FFF082 07F000904 clr mon_YSAVE
|
00FFF3A5 0CCFFF35C ldd #Monitor
|
00FFF085 07F000906 clr mon_USAVE
|
00FFF3A8 0FD00090B std mon_PCSAVE+1
|
00FFF088 0CC12D687 ldd #1234567
|
00FFF3AB 07F000902 clr mon_XSAVE
|
00FFF08B 0FD00092C std mon_init
|
00FFF3AE 07F000904 clr mon_YSAVE
|
|
00FFF3B1 07F000906 clr mon_USAVE
|
|
00FFF3B4 0CC12D687 ldd #1234567
|
|
00FFF3B7 0FD00092C std mon_init
|
mon1:
|
mon1:
|
00FFF08E 03280F006FFF leas $6FFF ; reset stack pointer
|
00FFF3BA 03280F006FFF leas $6FFF ; reset stack pointer
|
00FFF092 05F clrb ; turn off keyboard echo
|
00FFF3BE 05F clrb ; turn off keyboard echo
|
00FFF093 017FFFE4F lbsr SetKeyboardEcho
|
00FFF3BF 017FFFE0B lbsr SetKeyboardEcho
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
; Reset IO vectors
|
; Reset IO vectors
|
00FFF096 0CCFFEC64 ldd #SerialPeekCharDirect
|
00FFF3C2 0CCFFEC73 ldd #SerialPeekCharDirect
|
00FFF099 0FD000804 std CharInVec
|
00FFF3C5 0FD000804 std CharInVec
|
00FFF09C 0CCFFE319 ldd #DisplayChar
|
00FFF3C8 0CCFFE31C ldd #DisplayChar
|
00FFF09F 0FD000800 std CharOutVec
|
00FFF3CB 0FD000800 std CharOutVec
|
00FFF0A2 0CCFFF009 ldd #CmdPrompt
|
00FFF3CE 0CCFFF32C ldd #CmdPrompt
|
00FFF0A5 0FD000808 std CmdPromptJI
|
00FFF3D1 0FD000808 std CmdPromptJI
|
; jsr RequestIOFocus
|
; jsr RequestIOFocus
|
PromptLn:
|
PromptLn:
|
00FFF0A8 0AD90F000808 jsr [CmdPromptJI]
|
00FFF3D4 0AD90F000808 jsr [CmdPromptJI]
|
|
|
; Get characters until a CR is keyed
|
; Get characters until a CR is keyed
|
|
|
Prompt3:
|
Prompt3:
|
00FFF0AC 0CCFFFFFF ldd #-1 ; block until key present
|
00FFF3D8 0CCFFFFFF ldd #-1 ; block until key present
|
00FFF0AF 017FFFDF7 lbsr INCH
|
00FFF3DB 017FFFDB3 lbsr INCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF0B2 0C100D cmpb #CR ; carriage return?
|
00FFF3DE 04D tsta ; should not get this with blocking
|
00FFF0B4 027005 beq Prompt1
|
00FFF3DF 02BFF7 bmi Prompt3
|
00FFF0B6 017FFFE28 lbsr OUTCH ; spit out the character
|
00FFF3E1 0C100D cmpb #CR ; carriage return?
|
|
00FFF3E3 027005 beq Prompt1
|
|
00FFF3E5 017FFFDE1 lbsr OUTCH ; spit out the character
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF0B9 020FF1 bra Prompt3 ; and keep going
|
00FFF3E8 020FEE bra Prompt3 ; and keep going
|
|
|
; Process the screen line that the CR was keyed on
|
; Process the screen line that the CR was keyed on
|
;
|
;
|
Prompt1:
|
Prompt1:
|
00FFF0BB 0CC005050 ldd #$5050
|
00FFF3EA 0CC005050 ldd #$5050
|
00FFF0BE 0150FDFFFE60001 std LEDS
|
00FFF3ED 0150FDFFFE60001 std LEDS
|
; ldb RunningID
|
; ldb RunningID
|
; cmpb #61
|
; cmpb #61
|
; bhi Prompt3
|
; bhi Prompt3
|
00FFF0C3 00F111 clr CursorCol ; go back to the start of the line
|
00FFF3F2 00F111 clr CursorCol ; go back to the start of the line
|
00FFF0C5 017FFF22A lbsr CalcScreenLoc ; calc screen memory location
|
00FFF3F4 017FFEEFE lbsr CalcScreenLoc ; calc screen memory location
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF0C8 01F002 tfr d,y
|
00FFF3F7 01F002 tfr d,y
|
skipDollar:
|
skipDollar:
|
00FFF0CA 08D067 bsr MonGetNonSpace
|
00FFF3F9 08D067 bsr MonGetNonSpace
|
00FFF0CC 0C1024 cmpb #'$'
|
00FFF3FB 0C1024 cmpb #'$'
|
00FFF0CE 027FFA beq skipDollar ; skip over '$' prompt character
|
00FFF3FD 027FFA beq skipDollar ; skip over '$' prompt character
|
|
|
; Dispatch based on command
|
; Dispatch based on command
|
;
|
;
|
00FFF0D0 0313FF dey
|
00FFF3FF 0313FF dey
|
00FFF0D2 01F023 tfr y,u ; save off input position
|
00FFF401 01F023 tfr y,u ; save off input position
|
00FFF0D4 05F clrb
|
00FFF403 05F clrb
|
00FFF0D5 08EFFEFB2 ldx #cmdTable1
|
00FFF404 08EFFF29A ldx #cmdTable1
|
parseCmd1:
|
parseCmd1:
|
00FFF0D8 0A6A00 lda ,y+ ; get input character
|
00FFF407 0A6A00 lda ,y+ ; get input character
|
00FFF0DA 06D804 tst ,x ; test for end of command
|
00FFF409 06D804 tst ,x ; test for end of command
|
00FFF0DC 02B00F bmi endOfWord ;
|
00FFF40B 02B00F bmi endOfWord ;
|
00FFF0DE 0A1800 cmpa ,x+ ; does input match command?
|
00FFF40D 0A1800 cmpa ,x+ ; does input match command?
|
00FFF0E0 027FF6 beq parseCmd1
|
00FFF40F 027FF6 beq parseCmd1
|
scanNextWord:
|
scanNextWord:
|
00FFF0E2 06D800 tst ,x+
|
00FFF411 06D800 tst ,x+
|
00FFF0E4 027F53 beq Monitor ; if end of table reached, not a command
|
00FFF413 027F47 beq Monitor ; if end of table reached, not a command
|
00FFF0E6 02AFFA bpl scanNextWord
|
00FFF415 02AFFA bpl scanNextWord
|
00FFF0E8 05C incb
|
00FFF417 05C incb
|
00FFF0E9 01F032 tfr u,y ; reset input pointer
|
00FFF418 01F032 tfr u,y ; reset input pointer
|
00FFF0EB 020FEB bra parseCmd1 ; try again
|
00FFF41A 020FEB bra parseCmd1 ; try again
|
endOfWord:
|
endOfWord:
|
00FFF0ED 0A8804 eora ,x
|
00FFF41C 0A8804 eora ,x
|
00FFF0EF 048 asla
|
00FFF41E 048 asla
|
00FFF0F0 026FF0 bne scanNextWord
|
00FFF41F 026FF0 bne scanNextWord
|
; we found the command in the table
|
; we found the command in the table
|
00FFF0F2 058 aslb ; b = word index
|
00FFF421 058 aslb ; b = word index
|
00FFF0F3 08EFFEFE3 ldx #cmdTable2
|
00FFF422 08EFFF2EC ldx #cmdTable2
|
00FFF0F6 06E905 jmp [b,x] ; execute command
|
00FFF425 06E905 jmp [b,x] ; execute command
|
|
|
Redirect:
|
Redirect:
|
00FFF0F8 08D034 bsr MonGetch
|
00FFF427 08D034 bsr MonGetch
|
00FFF0FA 0C1073 cmpb #'s'
|
00FFF429 0C1073 cmpb #'s'
|
00FFF0FC 02600E bne Prompt2a
|
00FFF42B 02600E bne Prompt2a
|
00FFF0FE 0CCFFEC64 ldd #SerialPeekCharDirect
|
00FFF42D 0CCFFEC73 ldd #SerialPeekCharDirect
|
00FFF101 0FD000804 std CharInVec
|
00FFF430 0FD000804 std CharInVec
|
00FFF104 0CCFFEC88 ldd #SerialPutChar
|
00FFF433 0CCFFEC9A ldd #SerialPutChar
|
00FFF107 0FD000800 std CharOutVec
|
00FFF436 0FD000800 std CharOutVec
|
00FFF10A 020F2D bra Monitor
|
00FFF439 020F21 bra Monitor
|
Prompt2a:
|
Prompt2a:
|
00FFF10C 0C1063 cmpb #'c'
|
00FFF43B 0C1063 cmpb #'c'
|
00FFF10E 026F29 bne Monitor
|
00FFF43D 026F1D bne Monitor
|
00FFF110 0CCFFEA92 ldd #GetKey
|
00FFF43F 0CCFFEA92 ldd #GetKey
|
00FFF113 0FD000804 std CharInVec
|
00FFF442 0FD000804 std CharInVec
|
00FFF116 0CCFFE319 ldd #DisplayChar
|
00FFF445 0CCFFE31C ldd #DisplayChar
|
00FFF119 0FD000800 std CharOutVec
|
00FFF448 0FD000800 std CharOutVec
|
00FFF11C 020F1B bra Monitor
|
00FFF44B 020F0F bra Monitor
|
|
|
PromptHelp:
|
PromptHelp:
|
00FFF11E 0CCFFF2CF ldd #HelpMsg
|
00FFF44D 0CCFFF5FE ldd #HelpMsg
|
00FFF121 017FFF2B6 lbsr DisplayString
|
00FFF450 017FFEF8A lbsr DisplayString
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF124 020F13 bra Monitor
|
00FFF453 020F07 bra Monitor
|
|
|
PromptClearscreen:
|
PromptClearscreen:
|
00FFF126 017FFF110 lbsr ClearScreen
|
00FFF455 017FFEDE4 lbsr ClearScreen
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF129 017FFF184 lbsr HomeCursor
|
00FFF458 017FFEE58 lbsr HomeCursor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF12C 020F0B bra Monitor
|
00FFF45B 020EFF bra Monitor
|
|
|
MonGetch:
|
MonGetch:
|
00FFF12E 0E6A04 ldb ,y
|
00FFF45D 0E6A04 ldb ,y
|
00FFF130 031201 iny
|
00FFF45F 031201 iny
|
00FFF132 039 rts
|
00FFF461 039 rts
|
|
|
MonGetNonSpace:
|
MonGetNonSpace:
|
00FFF133 08DFF9 bsr MonGetCh
|
00FFF462 08DFF9 bsr MonGetCh
|
00FFF135 0C1020 cmpb #' '
|
00FFF464 0C1020 cmpb #' '
|
00FFF137 027FFA beq MonGetNonSpace
|
00FFF466 027FFA beq MonGetNonSpace
|
00FFF139 039 rts
|
00FFF468 039 rts
|
|
|
MonArmBreakpoint:
|
MonArmBreakpoint:
|
00FFF13A 017000611 lbsr ArmBreakpoint
|
00FFF469 0170006D5 lbsr ArmBreakpoint
|
00FFF13D 0C6FFF ldb #$FFF
|
00FFF46C 0C6FFF ldb #$FFF
|
00FFF13F 0F7000810 stb BreakpointFlag
|
00FFF46E 0F7000810 stb BreakpointFlag
|
00FFF142 016FFFEF4 lbra Monitor
|
00FFF471 016FFFEE8 lbra Monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
MonDisarmBreakpoint:
|
MonDisarmBreakpoint:
|
00FFF145 017000632 lbsr DisarmBreakpoint
|
00FFF474 017000700 lbsr DisarmBreakpoint
|
00FFF148 016FFFEEE lbra Monitor
|
00FFF477 016FFFEE2 lbra Monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Ignore blanks in the input
|
; Ignore blanks in the input
|
; Y = text pointer
|
; Y = text pointer
|
; D destroyed
|
; D destroyed
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
ignBlanks:
|
ignBlanks:
|
ignBlanks1:
|
ignBlanks1:
|
00FFF14B 08DFE1 bsr MonGetch
|
00FFF47A 08DFE1 bsr MonGetch
|
00FFF14D 0C1020 cmpb #' '
|
00FFF47C 0C1020 cmpb #' '
|
00FFF14F 027FFA beq ignBlanks1
|
00FFF47E 027FFA beq ignBlanks1
|
00FFF151 0313FF dey
|
00FFF480 0313FF dey
|
00FFF153 039 rts
|
00FFF482 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Multiply number in work area by 10.
|
; Multiply number in work area by 10.
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
Times10:
|
Times10:
|
00FFF154 034006 pshs d
|
00FFF483 034006 pshs d
|
00FFF156 0FC000910 ldd mon_numwka ; make a copy of the number
|
00FFF485 0FC000910 ldd mon_numwka ; make a copy of the number
|
00FFF159 0FD000918 std mon_numwka+8
|
00FFF488 0FD000918 std mon_numwka+8
|
00FFF15C 0FC000912 ldd mon_numwka+2
|
00FFF48B 0FC000912 ldd mon_numwka+2
|
00FFF15F 0FD00091A std mon_numwka+10
|
00FFF48E 0FD00091A std mon_numwka+10
|
00FFF162 08D05B bsr shl_numwka ; shift left = *2
|
00FFF491 08D05B bsr shl_numwka ; shift left = *2
|
00FFF164 08D059 bsr shl_numwka ; shift left = *4
|
00FFF493 08D059 bsr shl_numwka ; shift left = *4
|
00FFF166 0FC000912 ldd mon_numwka+2 ; add in original value
|
00FFF495 0FC000912 ldd mon_numwka+2 ; add in original value
|
00FFF169 0F300091A addd mon_numwka+10 ; = *5
|
00FFF498 0F300091A addd mon_numwka+10 ; = *5
|
00FFF16C 0F6000911 ldb mon_numwka+1
|
00FFF49B 0F6000911 ldb mon_numwka+1
|
00FFF16F 0F9000919 adcb mon_numwka+9
|
00FFF49E 0F9000919 adcb mon_numwka+9
|
00FFF172 0F7000911 stb mon_numwka+1
|
00FFF4A1 0F7000911 stb mon_numwka+1
|
00FFF175 0B6000910 lda mon_numwka+0
|
00FFF4A4 0B6000910 lda mon_numwka+0
|
00FFF178 0B9000918 adca mon_numwka+8
|
00FFF4A7 0B9000918 adca mon_numwka+8
|
00FFF17B 0B7000910 sta mon_numwka+0
|
00FFF4AA 0B7000910 sta mon_numwka+0
|
00FFF17E 08D03F bsr shl_numwka ; shift left = * 10
|
00FFF4AD 08D03F bsr shl_numwka ; shift left = * 10
|
00FFF180 035086 puls d,pc
|
00FFF4AF 035086 puls d,pc
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
GetTwoParams:
|
GetTwoParams:
|
00FFF182 08DFC7 bsr ignBlanks
|
00FFF4B1 08DFC7 bsr ignBlanks
|
00FFF184 08D0DC bsr GetNumber ; get start address of dump
|
00FFF4B3 08D0DC bsr GetNumber ; get start address of dump
|
00FFF186 0FC000910 ldd mon_numwka
|
00FFF4B5 0FC000910 ldd mon_numwka
|
00FFF189 0FD000920 std mon_r1
|
00FFF4B8 0FD000920 std mon_r1
|
00FFF18C 0FC000912 ldd mon_numwka+2
|
00FFF4BB 0FC000912 ldd mon_numwka+2
|
00FFF18F 0FD000922 std mon_r1+2
|
00FFF4BE 0FD000922 std mon_r1+2
|
00FFF192 08DFB7 bsr ignBlanks
|
00FFF4C1 08DFB7 bsr ignBlanks
|
00FFF194 08D0CC bsr GetNumber ; get end address of dump
|
00FFF4C3 08D0CC bsr GetNumber ; get end address of dump
|
00FFF196 0FC000910 ldd mon_numwka
|
00FFF4C5 0FC000910 ldd mon_numwka
|
00FFF199 0FD000924 std mon_r2
|
00FFF4C8 0FD000924 std mon_r2
|
00FFF19C 0FC000912 ldd mon_numwka+2
|
00FFF4CB 0FC000912 ldd mon_numwka+2
|
00FFF19F 0FD000926 std mon_r2+2
|
00FFF4CE 0FD000926 std mon_r2+2
|
00FFF1A2 039 rts
|
00FFF4D1 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Get a range, the end must be greater or equal to the start.
|
; Get a range, the end must be greater or equal to the start.
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
GetRange:
|
GetRange:
|
00FFF1A3 08DFDD bsr GetTwoParams
|
00FFF4D2 08DFDD bsr GetTwoParams
|
00FFF1A5 0FC000926 ldd mon_r2+2
|
00FFF4D4 0FC000926 ldd mon_r2+2
|
00FFF1A8 0B3000922 subd mon_r1+2
|
00FFF4D7 0B3000922 subd mon_r1+2
|
00FFF1AB 0FC000924 ldd mon_r2
|
00FFF4DA 0FC000924 ldd mon_r2
|
00FFF1AE 0F2000921 sbcb mon_r1+1
|
00FFF4DD 0F2000921 sbcb mon_r1+1
|
00FFF1B1 0B2000920 sbca mon_r1
|
00FFF4E0 0B2000920 sbca mon_r1
|
00FFF1B4 124000007 lbcc grng1
|
00FFF4E3 124000007 lbcc grng1
|
00FFF1B7 0AD90F00080C jsr [MonErrVec]
|
00FFF4E6 0AD90F00080C jsr [MonErrVec]
|
00FFF1BB 016FFFE7B lbra Monitor
|
00FFF4EA 016FFFE6F lbra Monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
grng1:
|
grng1:
|
00FFF1BE 039 rts
|
00FFF4ED 039 rts
|
|
|
shl_numwka:
|
shl_numwka:
|
00FFF1BF 078000913 asl mon_numwka+3
|
00FFF4EE 078000913 asl mon_numwka+3
|
00FFF1C2 079000912 rol mon_numwka+2
|
00FFF4F1 079000912 rol mon_numwka+2
|
00FFF1C5 079000911 rol mon_numwka+1
|
00FFF4F4 079000911 rol mon_numwka+1
|
00FFF1C8 079000910 rol mon_numwka
|
00FFF4F7 079000910 rol mon_numwka
|
00FFF1CB 039 rts
|
00FFF4FA 039 rts
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Get a hexidecimal number. Maximum of twelve digits.
|
; Get a hexidecimal number. Maximum of twelve digits.
|
;
|
;
|
; Modifies:
|
; Modifies:
|
Line 3536... |
Line 4131... |
; D = number of digits
|
; D = number of digits
|
; mon_numwka contains number
|
; mon_numwka contains number
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
GetHexNumber:
|
GetHexNumber:
|
00FFF1CC 04F05F clrd
|
00FFF4FB 04F05F clrd
|
00FFF1CE 0FD000910 std mon_numwka ; zero out work area
|
00FFF4FD 0FD000910 std mon_numwka ; zero out work area
|
00FFF1D1 0FD000912 std mon_numwka+2
|
00FFF500 0FD000912 std mon_numwka+2
|
00FFF1D4 034010 pshs x
|
00FFF503 034010 pshs x
|
00FFF1D6 08E000000 ldx #0 ; max 12 eight digits
|
00FFF505 08E000000 ldx #0 ; max 12 eight digits
|
gthxn2:
|
gthxn2:
|
00FFF1D9 08DF53 bsr MonGetch
|
00FFF508 08DF53 bsr MonGetch
|
00FFF1DB 08D093 bsr AsciiToHexNybble
|
00FFF50A 08D093 bsr AsciiToHexNybble
|
00FFF1DD 0C1FFF cmpb #-1
|
00FFF50C 0C1FFF cmpb #-1
|
00FFF1DF 027017 beq gthxn1
|
00FFF50E 027017 beq gthxn1
|
00FFF1E1 08DFDC bsr shl_numwka
|
00FFF510 08DFDC bsr shl_numwka
|
00FFF1E3 08DFDA bsr shl_numwka
|
00FFF512 08DFDA bsr shl_numwka
|
00FFF1E5 08DFD8 bsr shl_numwka
|
00FFF514 08DFD8 bsr shl_numwka
|
00FFF1E7 08DFD6 bsr shl_numwka
|
00FFF516 08DFD6 bsr shl_numwka
|
00FFF1E9 0C400F andb #$0f
|
00FFF518 0C400F andb #$0f
|
00FFF1EB 0FA000913 orb mon_numwka+3
|
00FFF51A 0FA000913 orb mon_numwka+3
|
00FFF1EE 0F7000913 stb mon_numwka+3
|
00FFF51D 0F7000913 stb mon_numwka+3
|
00FFF1F1 030001 inx
|
00FFF520 030001 inx
|
00FFF1F3 08C00000C cmpx #12
|
00FFF522 08C00000C cmpx #12
|
00FFF1F6 025FE1 blo gthxn2
|
00FFF525 025FE1 blo gthxn2
|
gthxn1:
|
gthxn1:
|
00FFF1F8 01F010 tfr x,d
|
00FFF527 01F010 tfr x,d
|
00FFF1FA 035090 puls x,pc
|
00FFF529 035090 puls x,pc
|
|
|
GetBinNumber:
|
GetBinNumber:
|
00FFF1FC 04F05F clrd
|
00FFF52B 04F05F clrd
|
00FFF1FE 0FD000910 std mon_numwka
|
00FFF52D 0FD000910 std mon_numwka
|
00FFF201 0FD000912 std mon_numwka+2
|
00FFF530 0FD000912 std mon_numwka+2
|
00FFF204 034010 pshs x
|
00FFF533 034010 pshs x
|
00FFF206 08E000000 ldx #0
|
00FFF535 08E000000 ldx #0
|
gtbin2:
|
gtbin2:
|
00FFF209 08DF23 bsr MonGetch
|
00FFF538 08DF23 bsr MonGetch
|
00FFF20B 08D099 bsr AsciiToBinDigit
|
00FFF53A 08D099 bsr AsciiToBinDigit
|
00FFF20D 05D tstb
|
00FFF53C 05D tstb
|
00FFF20E 02B00F bmi gtbin1
|
00FFF53D 02B00F bmi gtbin1
|
00FFF210 08DFAD bsr shl_numwka
|
00FFF53F 08DFAD bsr shl_numwka
|
00FFF212 0FA000913 orb mon_numwka+3
|
00FFF541 0FA000913 orb mon_numwka+3
|
00FFF215 0F7000913 stb mon_numwka+3
|
00FFF544 0F7000913 stb mon_numwka+3
|
00FFF218 030001 inx
|
00FFF547 030001 inx
|
00FFF21A 08C000030 cpx #48
|
00FFF549 08C000030 cpx #48
|
00FFF21D 025FEA blo gtbin2
|
00FFF54C 025FEA blo gtbin2
|
gtbin1:
|
gtbin1:
|
00FFF21F 01F010 tfr x,d
|
00FFF54E 01F010 tfr x,d
|
00FFF221 035090 puls x,pc
|
00FFF550 035090 puls x,pc
|
|
|
GetDecNumber:
|
GetDecNumber:
|
00FFF223 04F05F clrd
|
00FFF552 04F05F clrd
|
00FFF225 0FD000910 std mon_numwka
|
00FFF554 0FD000910 std mon_numwka
|
00FFF228 0FD000912 std mon_numwka+2
|
00FFF557 0FD000912 std mon_numwka+2
|
00FFF22B 034010 pshs x
|
00FFF55A 034010 pshs x
|
00FFF22D 08E000000 ldx #0
|
00FFF55C 08E000000 ldx #0
|
gtdec2:
|
gtdec2:
|
00FFF230 08DEFC bsr MonGetch
|
00FFF55F 08DEFC bsr MonGetch
|
00FFF232 08D064 bsr AsciiToDecDigit
|
00FFF561 08D064 bsr AsciiToDecDigit
|
00FFF234 05D tstb
|
00FFF563 05D tstb
|
00FFF235 02B027 bmi gtdec1
|
00FFF564 02B027 bmi gtdec1
|
00FFF237 08DF1B bsr Times10
|
00FFF566 08DF1B bsr Times10
|
00FFF239 0FB000913 addb mon_numwka+3
|
00FFF568 0FB000913 addb mon_numwka+3
|
00FFF23C 0F7000913 stb mon_numwka+3
|
00FFF56B 0F7000913 stb mon_numwka+3
|
00FFF23F 0F6000912 ldb mon_numwka+2
|
00FFF56E 0F6000912 ldb mon_numwka+2
|
00FFF242 0C9000 adcb #0
|
00FFF571 0C9000 adcb #0
|
00FFF244 0F7000912 stb mon_numwka+2
|
00FFF573 0F7000912 stb mon_numwka+2
|
00FFF247 0F6000911 ldb mon_numwka+1
|
00FFF576 0F6000911 ldb mon_numwka+1
|
00FFF24A 0C9000 adcb #0
|
00FFF579 0C9000 adcb #0
|
00FFF24C 0F7000911 stb mon_numwka+1
|
00FFF57B 0F7000911 stb mon_numwka+1
|
00FFF24F 0F6000910 ldb mon_numwka+0
|
00FFF57E 0F6000910 ldb mon_numwka+0
|
00FFF252 0C9000 adcb #0
|
00FFF581 0C9000 adcb #0
|
00FFF254 0F7000910 stb mon_numwka+0
|
00FFF583 0F7000910 stb mon_numwka+0
|
00FFF257 030001 inx
|
00FFF586 030001 inx
|
00FFF259 08C00000F cpx #15
|
00FFF588 08C00000F cpx #15
|
00FFF25C 025FD2 blo gtdec2
|
00FFF58B 025FD2 blo gtdec2
|
gtdec1:
|
gtdec1:
|
00FFF25E 01F010 tfr x,d
|
00FFF58D 01F010 tfr x,d
|
00FFF260 035090 puls x,pc
|
00FFF58F 035090 puls x,pc
|
|
|
GetNumber:
|
GetNumber:
|
00FFF262 08DECA bsr MonGetch
|
00FFF591 08DECA bsr MonGetch
|
00FFF264 0C102B cmpb #'+'
|
00FFF593 0C102B cmpb #'+'
|
00FFF266 027FBB beq GetDecNumber
|
00FFF595 027FBB beq GetDecNumber
|
00FFF268 0C1025 cmpb #'%'
|
00FFF597 0C1025 cmpb #'%'
|
00FFF26A 027F90 beq GetBinNumber
|
00FFF599 027F90 beq GetBinNumber
|
00FFF26C 0313FF dey
|
00FFF59B 0313FF dey
|
00FFF26E 020F5C bra GetHexNumber
|
00FFF59D 020F5C bra GetHexNumber
|
|
|
; phx
|
; phx
|
; push r4
|
; push r4
|
; push r5
|
; push r5
|
; ldx #0
|
; ldx #0
|
Line 3648... |
Line 4243... |
; Convert ASCII character in the range '0' to '9', 'a' to 'f' or 'A' to 'F'
|
; Convert ASCII character in the range '0' to '9', 'a' to 'f' or 'A' to 'F'
|
; to a hex nybble.
|
; to a hex nybble.
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;
|
;
|
AsciiToHexNybble:
|
AsciiToHexNybble:
|
00FFF270 0C1030 cmpb #'0'
|
00FFF59F 0C1030 cmpb #'0'
|
00FFF272 025021 blo gthx3
|
00FFF5A1 025021 blo gthx3
|
00FFF274 0C1039 cmpb #'9'
|
00FFF5A3 0C1039 cmpb #'9'
|
00FFF276 022003 bhi gthx5
|
00FFF5A5 022003 bhi gthx5
|
00FFF278 0C0030 subb #'0'
|
00FFF5A7 0C0030 subb #'0'
|
00FFF27A 039 rts
|
00FFF5A9 039 rts
|
gthx5:
|
gthx5:
|
00FFF27B 0C1041 cmpb #'A'
|
00FFF5AA 0C1041 cmpb #'A'
|
00FFF27D 025016 blo gthx3
|
00FFF5AC 025016 blo gthx3
|
00FFF27F 0C1046 cmpb #'F'
|
00FFF5AE 0C1046 cmpb #'F'
|
00FFF281 022005 bhi gthx6
|
00FFF5B0 022005 bhi gthx6
|
00FFF283 0C0041 subb #'A'
|
00FFF5B2 0C0041 subb #'A'
|
00FFF285 0CB00A addb #10
|
00FFF5B4 0CB00A addb #10
|
00FFF287 039 rts
|
00FFF5B6 039 rts
|
gthx6:
|
gthx6:
|
00FFF288 0C1061 cmpb #'a'
|
00FFF5B7 0C1061 cmpb #'a'
|
00FFF28A 025009 blo gthx3
|
00FFF5B9 025009 blo gthx3
|
00FFF28C 0C107A cmpb #'z'
|
00FFF5BB 0C107A cmpb #'z'
|
00FFF28E 022005 bhi gthx3
|
00FFF5BD 022005 bhi gthx3
|
00FFF290 0C0061 subb #'a'
|
00FFF5BF 0C0061 subb #'a'
|
00FFF292 0CB00A addb #10
|
00FFF5C1 0CB00A addb #10
|
00FFF294 039 rts
|
00FFF5C3 039 rts
|
gthx3:
|
gthx3:
|
00FFF295 0C6FFF ldb #-1 ; not a hex number
|
00FFF5C4 0C6FFF ldb #-1 ; not a hex number
|
00FFF297 039 rts
|
00FFF5C6 039 rts
|
|
|
AsciiToDecDigit:
|
AsciiToDecDigit:
|
00FFF298 0C1030 cmpb #'0'
|
00FFF5C7 0C1030 cmpb #'0'
|
00FFF29A 025007 blo gtdc3
|
00FFF5C9 025007 blo gtdc3
|
00FFF29C 0C1039 cmpb #'9'
|
00FFF5CB 0C1039 cmpb #'9'
|
00FFF29E 022003 bhi gtdc3
|
00FFF5CD 022003 bhi gtdc3
|
00FFF2A0 0C0030 subb #'0'
|
00FFF5CF 0C0030 subb #'0'
|
00FFF2A2 039 rts
|
00FFF5D1 039 rts
|
gtdc3:
|
gtdc3:
|
00FFF2A3 0C6FFF ldb #-1
|
00FFF5D2 0C6FFF ldb #-1
|
00FFF2A5 039 rts
|
00FFF5D4 039 rts
|
|
|
AsciiToBinDigit:
|
AsciiToBinDigit:
|
00FFF2A6 0C1030 cmpb #'0'
|
00FFF5D5 0C1030 cmpb #'0'
|
00FFF2A8 026002 bne abd1
|
00FFF5D7 026002 bne abd1
|
00FFF2AA 05F clrb
|
00FFF5D9 05F clrb
|
00FFF2AB 039 rts
|
00FFF5DA 039 rts
|
abd1:
|
abd1:
|
00FFF2AC 0C1031 cmpb #'1'
|
00FFF5DB 0C1031 cmpb #'1'
|
00FFF2AE 026003 bne abd2
|
00FFF5DD 026003 bne abd2
|
00FFF2B0 0C6001 ldb #1
|
00FFF5DF 0C6001 ldb #1
|
00FFF2B2 039 rts
|
00FFF5E1 039 rts
|
abd2:
|
abd2:
|
00FFF2B3 0C6FFF ldb #-1
|
00FFF5E2 0C6FFF ldb #-1
|
00FFF2B5 039 rts
|
00FFF5E4 039 rts
|
|
|
DisplayErr:
|
DisplayErr:
|
00FFF2B6 0CCFFF2C7 ldd #msgErr
|
00FFF5E5 0CCFFF5F6 ldd #msgErr
|
00FFF2B9 017FFF11E lbsr DisplayString
|
00FFF5E8 017FFEDF2 lbsr DisplayString
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF2BC 07EFFF039 jmp Monitor
|
00FFF5EB 07EFFF35C jmp Monitor
|
|
|
DisplayStringDX
|
DisplayStringDX
|
00FFF2BF 0DD024 std Strptr
|
00FFF5EE 0DD024 std Strptr
|
00FFF2C1 09F026 stx Strptr+2
|
00FFF5F0 09F026 stx Strptr+2
|
00FFF2C3 0BDFFE3DA jsr DisplayString
|
00FFF5F2 0BDFFE3DD jsr DisplayString
|
00FFF2C6 039 rts
|
00FFF5F5 039 rts
|
|
|
msgErr:
|
msgErr:
|
00FFF2C7 02A02A04507207200D00A fcb "**Err",CR,LF,0
|
00FFF5F6 02A02A04507207200D00A fcb "**Err",CR,LF,0
|
00FFF2CE 000
|
00FFF5FD 000
|
|
|
HelpMsg:
|
HelpMsg:
|
00FFF2CF 03F02003D020044069073 fcb "? = Display help",CR,LF
|
00FFF5FE 03F02003D020044069073 fcb "? = Display help",CR,LF
|
00FFF2D6 07006C061079020068065
|
00FFF605 07006C061079020068065
|
00FFF2DD 06C07000D00A
|
00FFF60C 06C07000D00A
|
00FFF2E1 04304C05302003D020063 fcb "CLS = clear screen",CR,LF
|
00FFF610 04304C05302003D020063 fcb "CLS = clear screen",CR,LF
|
00FFF2E8 06C065061072020073063
|
00FFF617 06C065061072020073063
|
00FFF2EF 07206506506E00D00A
|
00FFF61E 07206506506E00D00A
|
00FFF2F5 06207302003D020073065 fcb "bs = set breakpoint",CR,LF
|
00FFF624 06202B02003D020073065 fcb "b+ = set breakpoint",CR,LF
|
00FFF2FC 07402006207206506106B
|
00FFF62B 07402006207206506106B
|
00FFF303 07006F06906E07400D00A
|
00FFF632 07006F06906E07400D00A
|
00FFF30A 06206302003D02006306C fcb "bc = clear breakpoint",CR,LF
|
00FFF639 06202D02003D02006306C fcb "b- = clear breakpoint",CR,LF
|
00FFF311 065061072020062072065
|
00FFF640 065061072020062072065
|
00FFF318 06106B07006F06906E074
|
00FFF647 06106B07006F06906E074
|
00FFF31F 00D00A
|
00FFF64E 00D00A
|
; db "S = Boot from SD Card",CR,LF
|
; db "S = Boot from SD Card",CR,LF
|
00FFF321 03A02003D020045064069 fcb ": = Edit memory bytes",CR,LF
|
00FFF650 03A02003D020045064069 fcb ": = Edit memory bytes",CR,LF
|
00FFF328 07402006D06506D06F072
|
00FFF657 07402006D06506D06F072
|
00FFF32F 079020062079074065073
|
00FFF65E 079020062079074065073
|
00FFF336 00D00A
|
00FFF665 00D00A
|
; db "L = Load sector",CR,LF
|
; db "L = Load sector",CR,LF
|
; db "W = Write sector",CR,LF
|
; db "W = Write sector",CR,LF
|
00FFF338 04405202003D020044075 fcb "DR = Dump registers",CR,LF
|
00FFF667 04405202003D020044075 fcb "DR = Dump registers",CR,LF
|
00FFF33F 06D070020072065067069
|
00FFF66E 06D070020072065067069
|
00FFF346 07307406507207300D00A
|
00FFF675 07307406507207300D00A
|
00FFF34D 04402003D02004407506D fcb "D = Dump memory",CR,LF
|
00FFF67C 04402003D02004407506D fcb "D = Dump memory",CR,LF
|
00FFF354 07002006D06506D06F072
|
00FFF683 07002006D06506D06F072
|
00FFF35B 07900D00A
|
00FFF68A 07900D00A
|
00FFF35E 04602003D02004606906C fcb "F = Fill memory",CR,LF
|
00FFF68D 04602003D02004606906C fcb "F = Fill memory",CR,LF
|
00FFF365 06C02006D06506D06F072
|
00FFF694 06C02006D06506D06F072
|
00FFF36C 07900D00A
|
00FFF69B 07900D00A
|
00FFF36F 04604C02003D020044075 fcb "FL = Dump I/O Focus List",CR,LF
|
00FFF69E 04604C02003D020044075 fcb "FL = Dump I/O Focus List",CR,LF
|
00FFF376 06D07002004902F04F020
|
00FFF6A5 06D07002004902F04F020
|
00FFF37D 04606F06307507302004C
|
00FFF6AC 04606F06307507302004C
|
00FFF384 06907307400D00A
|
00FFF6B3 06907307400D00A
|
; fcb "FIG = start FIG Forth",CR,LF
|
; fcb "FIG = start FIG Forth",CR,LF
|
; db "KILL n = kill task #n",CR,LF
|
; db "KILL n = kill task #n",CR,LF
|
; db "B = start tiny basic",CR,LF
|
; db "B = start tiny basic",CR,LF
|
; db "b = start EhBasic 6502",CR,LF
|
; db "b = start EhBasic 6502",CR,LF
|
00FFF389 04A02003D02004A07506D fcb "J = Jump to code",CR,LF
|
00FFF6B8 04A02003D02004A07506D fcb "J = Jump to code",CR,LF
|
00FFF390 07002007406F02006306F
|
00FFF6BF 07002007406F02006306F
|
00FFF397 06406500D00A
|
00FFF6C6 06406500D00A
|
00FFF39B 04A04403402003D02004A fcb "JD4 = Jump to $FFD400",CR,LF
|
00FFF6CA 04A04403402003D02004A fcb "JD4 = Jump to $FFD400",CR,LF
|
00FFF3A2 07506D07002007406F020
|
00FFF6D1 07506D07002007406F020
|
00FFF3A9 024046046044034030030
|
00FFF6D8 024046046044034030030
|
00FFF3B0 00D00A
|
00FFF6DF 00D00A
|
00FFF3B2 05204104D054045053054 fcb "RAMTEST = test RAM",CR,LF
|
00FFF6E1 05205B06E05D02003D020 fcb "R[n] = Set register value",CR,LF
|
00FFF3B9 02003D020074065073074
|
00FFF6E8 053065074020072065067
|
00FFF3C0 02005204104D00D00A
|
00FFF6EF 069073074065072020076
|
; db "R[n] = Set register value",CR,LF
|
00FFF6F6 06106C07506500D00A
|
; db "r = random lines - test bitmap",CR,LF
|
; db "r = random lines - test bitmap",CR,LF
|
; db "e = ethernet test",CR,LF
|
; db "e = ethernet test",CR,LF
|
00FFF3C6 07302003D020073065072 fcb "s = serial output test",CR,LF
|
00FFF6FC 07302003D020073065072 fcb "s = serial output test",CR,LF
|
00FFF3CD 06906106C02006F075074
|
00FFF703 06906106C02006F075074
|
00FFF3D4 070075074020074065073
|
00FFF70A 070075074020074065073
|
00FFF3DB 07400D00A
|
00FFF711 07400D00A
|
00FFF3DE 05303103902003D020072 fcb "S19 = run S19 loader",CR,LF
|
00FFF714 05303103902003D020072 fcb "S19 = run S19 loader",CR,LF
|
00FFF3E5 07506E020053031039020
|
00FFF71B 07506E020053031039020
|
00FFF3EC 06C06F06106406507200D
|
00FFF722 06C06F06106406507200D
|
00FFF3F3 00A
|
00FFF729 00A
|
00FFF3F4 05305002003D020073070 fcb "SP = sprite demo",CR,LF
|
00FFF72A 05305002003D020073070 fcb "SP = sprite demo",CR,LF
|
00FFF3FB 072069074065020064065
|
00FFF731 072069074065020064065
|
00FFF402 06D06F00D00A
|
00FFF738 06D06F00D00A
|
; db "T = Dump task list",CR,LF
|
; db "T = Dump task list",CR,LF
|
; db "TO = Dump timeout list",CR,LF
|
; db "TO = Dump timeout list",CR,LF
|
00FFF406 05404902003D020064069 fcb "TI = display date/time",CR,LF
|
00FFF73C 05404902003D020064069 fcb "TI = display date/time",CR,LF
|
00FFF40D 07307006C061079020064
|
00FFF743 07307006C061079020064
|
00FFF414 06107406502F07406906D
|
00FFF74A 06107406502F07406906D
|
00FFF41B 06500D00A
|
00FFF751 06500D00A
|
; db "TEMP = display temperature",CR,LF
|
; db "TEMP = display temperature",CR,LF
|
00FFF41E 05502003D02007506E061 fcb "U = unassemble",CR,LF
|
00FFF754 05502003D02007506E061 fcb "U = unassemble",CR,LF
|
00FFF425 07307306506D06206C065
|
00FFF75B 07307306506D06206C065
|
00FFF42C 00D00A
|
00FFF762 00D00A
|
; db "P = Piano",CR,LF
|
; db "P = Piano",CR,LF
|
00FFF42E 07802003D020065078069 fcb "x = exit monitor",CR,LF
|
00FFF764 05804D02003D02007806D fcb "XM = xmodem transfer",CR,LF
|
00FFF435 07402006D06F06E069074
|
00FFF76B 06F06406506D020074072
|
00FFF43C 06F07200D00A
|
00FFF772 06106E07306606507200D
|
00FFF440 000 fcb 0
|
00FFF779 00A
|
|
00FFF77A 07802003D020065078069 fcb "x = exit monitor",CR,LF
|
|
00FFF781 07402006D06F06E069074
|
|
00FFF788 06F07200D00A
|
|
00FFF78C 000 fcb 0
|
|
|
msgRegHeadings
|
msgRegHeadings
|
00FFF441 00D00A02002004402F041 fcb CR,LF," D/AB X Y U S PC DP CCR",CR,LF,0
|
00FFF78D 00D00A02002004402F041 fcb CR,LF," D/AB X Y U S PC DP CCR",CR,LF,0
|
00FFF448 042020020020020020058
|
00FFF794 042020020020020020058
|
00FFF44F 020020020020020020059
|
00FFF79B 020020020020020020059
|
00FFF456 020020020020020020055
|
00FFF7A2 020020020020020020055
|
00FFF45D 020020020020020020053
|
00FFF7A9 020020020020020020053
|
00FFF464 020020020020020020020
|
00FFF7B0 020020020020020020020
|
00FFF46B 050043020020020020044
|
00FFF7B7 050043020020020020044
|
00FFF472 05002002004304305200D
|
00FFF7BE 05002002004304305200D
|
00FFF479 00A000
|
00FFF7C5 00A000
|
|
|
nHEX4:
|
nHEX4:
|
00FFF47B 0BDFFD2D2 jsr HEX4
|
00FFF7C7 0BDFFD2D2 jsr HEX4
|
00FFF47E 039 rts
|
00FFF7CA 039 rts
|
|
|
nXBLANK:
|
nXBLANK:
|
00FFF47F 0C6020 ldb #' '
|
00FFF7CB 0C6020 ldb #' '
|
00FFF481 016FFFA5D lbra OUTCH
|
00FFF7CD 016FFF9F9 lbra OUTCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Dump Memory
|
; Dump Memory
|
;
|
;
|
Line 3825... |
Line 4424... |
; :FFFC12 012 012 012 012 555 666 777 888
|
; :FFFC12 012 012 012 012 555 666 777 888
|
;
|
;
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
DumpMemory:
|
DumpMemory:
|
00FFF484 08DD1D bsr GetRange
|
00FFF7D0 08DD00 bsr GetRange
|
00FFF486 18E000000 ldy #0
|
00FFF7D2 18E000000 ldy #0
|
00FFF489 1BE000922 ldy mon_r1+2
|
00FFF7D5 1BE000922 ldy mon_r1+2
|
dmpm2:
|
dmpm2:
|
00FFF48C 017FFDC43 lbsr CRLF
|
00FFF7D8 017FFD8F7 lbsr CRLF
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF48F 0C603A ldb #':'
|
00FFF7DB 0C603A ldb #':'
|
00FFF491 017FFFA4D lbsr OUTCH
|
00FFF7DD 017FFF9E9 lbsr OUTCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF494 01F020 tfr y,d
|
00FFF7E0 01F020 tfr y,d
|
;addd mon_r1+2 ; output the address
|
;addd mon_r1+2 ; output the address
|
00FFF496 017FFEF95 lbsr DispWordAsHex
|
00FFF7E2 017FFEC4C lbsr DispWordAsHex
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF499 0C6020 ldb #' '
|
00FFF7E5 0C6020 ldb #' '
|
00FFF49B 017FFFA43 lbsr OUTCH
|
00FFF7E7 017FFF9DF lbsr OUTCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF49E 08E000008 ldx #8 ; number of bytes to display
|
00FFF7EA 08E000008 ldx #8 ; number of bytes to display
|
dmpm1:
|
dmpm1:
|
; ldb far [mon_r1+1],y
|
; ldb far [mon_r1+1],y
|
;ldb [mon_r1+2],y
|
;ldb [mon_r1+2],y
|
00FFF4A1 0E6A04 ldb ,y
|
00FFF7ED 0E6A04 ldb ,y
|
00FFF4A3 031201 iny
|
00FFF7EF 031201 iny
|
00FFF4A5 017FFEF8F lbsr DispByteAsHex ; display byte
|
00FFF7F1 017FFEC46 lbsr DispByteAsHex ; display byte
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF4A8 0C6020 ldb #' ' ; followed by a space
|
00FFF7F4 0C6020 ldb #' ' ; followed by a space
|
00FFF4AA 017FFFA34 lbsr OUTCH
|
00FFF7F6 017FFF9D0 lbsr OUTCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF4AD 05F clrb
|
00FFF7F9 05F clrb
|
00FFF4AE 04F clra
|
00FFF7FA 04F clra
|
00FFF4AF 017FFF9F7 lbsr INCH
|
00FFF7FB 017FFF993 lbsr INCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF4B2 0C1003 cmpb #CTRLC
|
00FFF7FE 0C1003 cmpb #CTRLC
|
00FFF4B4 027024 beq dmpm3
|
00FFF800 027024 beq dmpm3
|
00FFF4B6 0301FF dex
|
00FFF802 0301FF dex
|
00FFF4B8 026FE7 bne dmpm1
|
00FFF804 026FE7 bne dmpm1
|
; Now output ascii
|
; Now output ascii
|
00FFF4BA 0C6020 ldb #' '
|
00FFF806 0C6020 ldb #' '
|
00FFF4BC 017FFFA22 lbsr OUTCH
|
00FFF808 017FFF9BE lbsr OUTCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF4BF 08E000008 ldx #8 ; 8 chars to output
|
00FFF80B 08E000008 ldx #8 ; 8 chars to output
|
00FFF4C2 0313F8 leay -8,y ; backup pointer
|
00FFF80E 0313F8 leay -8,y ; backup pointer
|
dmpm5:
|
dmpm5:
|
; ldb far [mon_r1+1],y ; get the char
|
; ldb far [mon_r1+1],y ; get the char
|
; ldb [mon_r1+2],y ; get the char
|
; ldb [mon_r1+2],y ; get the char
|
00FFF4C4 0E6A04 ldb ,y
|
00FFF810 0E6A04 ldb ,y
|
00FFF4C6 0C1020 cmpb #$20 ; is it a control char?
|
00FFF812 0C1020 cmpb #$20 ; is it a control char?
|
00FFF4C8 024002 bhs dmpm4
|
00FFF814 024002 bhs dmpm4
|
00FFF4CA 0C602E ldb #'.'
|
00FFF816 0C602E ldb #'.'
|
dmpm4:
|
dmpm4:
|
00FFF4CC 017FFFA12 lbsr OUTCH
|
00FFF818 017FFF9AE lbsr OUTCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF4CF 031201 iny
|
00FFF81B 031201 iny
|
00FFF4D1 0301FF dex
|
00FFF81D 0301FF dex
|
00FFF4D3 026FEF bne dmpm5
|
00FFF81F 026FEF bne dmpm5
|
00FFF4D5 1BC000926 cmpy mon_r2+2
|
00FFF821 1BC000926 cmpy mon_r2+2
|
00FFF4D8 025FB2 blo dmpm2
|
00FFF824 025FB2 blo dmpm2
|
dmpm3:
|
dmpm3:
|
00FFF4DA 017FFDBF5 lbsr CRLF
|
00FFF826 017FFD8A9 lbsr CRLF
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF4DD 016FFFB59 lbra Monitor
|
00FFF829 016FFFB30 lbra Monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Edit Memory
|
; Edit Memory
|
;
|
;
|
Line 3899... |
Line 4498... |
; :FFFC12 012 012 012 012 555 666 777 888
|
; :FFFC12 012 012 012 012 555 666 777 888
|
;
|
;
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
EditMemory:
|
EditMemory:
|
00FFF4E0 0CE000008 ldu #8 ; set max byte count
|
00FFF82C 0CE000008 ldu #8 ; set max byte count
|
00FFF4E3 017FFFCE6 lbsr GetHexNumber ; get the start address
|
00FFF82F 017FFFC48 lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF832 017FFFCC6 lbsr GetHexNumber ; get the start address
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF4E6 0BE000912 ldx mon_numwka+2
|
00FFF835 0BE000912 ldx mon_numwka+2
|
EditMem2:
|
EditMem2:
|
00FFF4E9 017FFFC5F lbsr ignBlanks ; skip over blanks
|
00FFF838 017FFFC3F lbsr ignBlanks ; skip over blanks
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF4EC 017FFFCDD lbsr GetHexNumber ; get the byte value
|
00FFF83B 017FFFCBD lbsr GetHexNumber ; get the byte value
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF4EF 05D tstb ; check for valid value
|
00FFF83E 05D tstb ; check for valid value
|
00FFF4F0 02700C beq EditMem1 ; if invalid, quit
|
00FFF83F 02700C beq EditMem1 ; if invalid, quit
|
00FFF4F2 0F6000913 ldb mon_numwka+3 ; get value
|
00FFF841 0F6000913 ldb mon_numwka+3 ; get value
|
00FFF4F5 0E7800 stb ,x+ ; update memory at address
|
00FFF844 0E7800 stb ,x+ ; update memory at address
|
00FFF4F7 0335FF leau -1,u ; decremeent byte count
|
00FFF846 0335FF leau -1,u ; decremeent byte count
|
00FFF4F9 283000000 cmpu #0
|
00FFF848 283000000 cmpu #0
|
00FFF4FC 026FEB bne EditMem2 ; go back for annother byte
|
00FFF84B 026FEB bne EditMem2 ; go back for annother byte
|
EditMem1:
|
EditMem1:
|
00FFF4FE 017FFFC2D lbsr MonGetch ; see if a string is being entered
|
00FFF84D 017FFFC0D lbsr MonGetch ; see if a string is being entered
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF501 0C1022 cmpb #'"'
|
00FFF850 0C1022 cmpb #'"'
|
00FFF503 026018 bne EditMem3 ; no string, we're done
|
00FFF852 026018 bne EditMem3 ; no string, we're done
|
00FFF505 0CE000028 ldu #40 ; string must be less than 40 chars
|
00FFF854 0CE000028 ldu #40 ; string must be less than 40 chars
|
EditMem4:
|
EditMem4:
|
00FFF508 017FFFC23 lbsr MonGetch ; look for close quote
|
00FFF857 017FFFC03 lbsr MonGetch ; look for close quote
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF50B 0C1022 cmpb #'"'
|
00FFF85A 0C1022 cmpb #'"'
|
00FFF50D 026005 bne EditMem6 ; end of string?
|
00FFF85C 026005 bne EditMem6 ; end of string?
|
00FFF50F 0CE000008 ldu #8 ; reset the byte count
|
00FFF85E 0CE000008 ldu #8 ; reset the byte count
|
00FFF512 020FD5 bra EditMem2
|
00FFF861 020FD5 bra EditMem2
|
EditMem6:
|
EditMem6:
|
00FFF514 0E7800 stb ,x+ ; store the character in memory
|
00FFF863 0E7800 stb ,x+ ; store the character in memory
|
00FFF516 0335FF leau -1,u ; decrement byte count
|
00FFF865 0335FF leau -1,u ; decrement byte count
|
00FFF518 283000000 cmpu #0
|
00FFF867 283000000 cmpu #0
|
00FFF51B 022FEB bhi EditMem4 ; max 40 chars
|
00FFF86A 022FEB bhi EditMem4 ; max 40 chars
|
EditMem3:
|
EditMem3:
|
00FFF51D 016FFFB19 lbra Monitor
|
00FFF86C 016FFFAED lbra Monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Fill Memory
|
; Fill Memory
|
Line 3947... |
Line 4548... |
; $$F FFFC12 FFFC30 89F
|
; $$F FFFC12 FFFC30 89F
|
;
|
;
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
FillMemory:
|
FillMemory:
|
00FFF520 017FFFC80 lbsr GetRange ; get address range to fill
|
00FFF86F 017FFFC60 lbsr GetRange ; get address range to fill
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF523 017FFFC25 lbsr ignBlanks
|
00FFF872 017FFFC05 lbsr ignBlanks
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF526 017FFFCA3 lbsr GetHexNumber ; get target byte to write
|
00FFF875 017FFFC83 lbsr GetHexNumber ; get target byte to write
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF529 0F6000913 ldb mon_numwka+3
|
00FFF878 0F6000913 ldb mon_numwka+3
|
00FFF52C 0BE000922 ldx mon_r1+2
|
00FFF87B 0BE000922 ldx mon_r1+2
|
00FFF52F 04F clra
|
00FFF87E 04F clra
|
fillm1: ; Check for a CTRL-C every page of memory
|
fillm1: ; Check for a CTRL-C every page of memory
|
00FFF530 04D tsta
|
00FFF87F 04D tsta
|
00FFF531 02600D bne fillm2
|
00FFF880 02600D bne fillm2
|
00FFF533 05F clrb ; we want a non-blocking check
|
00FFF882 05F clrb ; we want a non-blocking check
|
00FFF534 04F clra
|
00FFF883 04F clra
|
00FFF535 017FFF971 lbsr INCH
|
00FFF884 017FFF90A lbsr INCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF538 0C1003 cmpb #CTRLC
|
00FFF887 0C1003 cmpb #CTRLC
|
00FFF53A 127FFFAFC lbeq Monitor
|
00FFF889 127FFFAD0 lbeq Monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF53D 0F6000913 ldb mon_numwka+3 ; reset target byte
|
00FFF88C 0F6000913 ldb mon_numwka+3 ; reset target byte
|
fillm2:
|
fillm2:
|
00FFF540 0E7800 stb ,x+
|
00FFF88F 0E7800 stb ,x+
|
00FFF542 0BC000926 cmpx mon_r2+2
|
00FFF891 0BC000926 cmpx mon_r2+2
|
00FFF545 023FE9 bls fillm1
|
00FFF894 023FE9 bls fillm1
|
fillm3:
|
fillm3:
|
00FFF547 016FFFAEF lbra Monitor
|
00FFF896 016FFFAC3 lbra Monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Dump Registers
|
; Dump Registers
|
;
|
;
|
; Usage:
|
; Usage:
|
; $DR
|
; $DR
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
DumpRegs:
|
DumpRegs:
|
00FFF54A 0CCFFF441 ldd #msgRegHeadings
|
00FFF899 0CCFFF78D ldd #msgRegHeadings
|
00FFF54D 017FFEE8A lbsr DisplayString
|
00FFF89C 017FFEB3E lbsr DisplayString
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF89F 08DF2A bsr nXBLANK
|
|
00FFF8A1 0FC000900 ldd mon_DSAVE
|
|
00FFF8A4 08DF21 bsr nHEX4
|
|
00FFF8A6 08DF23 bsr nXBLANK
|
|
00FFF8A8 0FC000902 ldd mon_XSAVE
|
|
00FFF8AB 08DF1A bsr nHEX4
|
|
00FFF8AD 08DF1C bsr nXBLANK
|
|
00FFF8AF 0FC000904 ldd mon_YSAVE
|
|
00FFF8B2 08DF13 bsr nHEX4
|
|
00FFF8B4 08DF15 bsr nXBLANK
|
|
00FFF8B6 0FC000906 ldd mon_USAVE
|
|
00FFF8B9 08DF0C bsr nHEX4
|
|
00FFF8BB 08DF0E bsr nXBLANK
|
|
00FFF8BD 0FC000908 ldd mon_SSAVE
|
|
00FFF8C0 08DF05 bsr nHEX4
|
|
00FFF8C2 08DF07 bsr nXBLANK
|
|
00FFF8C4 0F600090B ldb mon_PCSAVE+1
|
|
00FFF8C7 017FFEB70 lbsr DispByteAsHex
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF8CA 0FC00090C ldd mon_PCSAVE+2
|
|
00FFF8CD 08DEF8 bsr nHEX4
|
|
00FFF8CF 08DEFA bsr nXBLANK
|
|
00FFF8D1 0FC00090E ldd mon_DPRSAVE
|
|
00FFF8D4 0BDFFD2CE jsr HEX2
|
|
00FFF8D7 08DEF2 bsr nXBLANK
|
|
00FFF8D9 0B600090F lda mon_CCRSAVE
|
|
00FFF8DC 017FFD9EF lbsr HEX2
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF8DF 08DEEA bsr nXBLANK
|
|
00FFF8E1 016FFFA78 lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
|
;------------------------------------------------------------------------------
|
|
; SetRegXXX
|
|
;
|
|
; Set the value to be loaded into a register.
|
|
;------------------------------------------------------------------------------
|
|
|
|
SetRegA:
|
|
00FFF8E4 017FFFB93 lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF8E7 017FFFCA7 lbsr GetNumber
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF8EA 0B6000913 lda mon_numwka+3
|
|
00FFF8ED 0B7000900 sta mon_DSAVE
|
|
00FFF8F0 016FFFA69 lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
SetRegB:
|
|
00FFF8F3 017FFFB84 lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF8F6 017FFFC98 lbsr GetNumber
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF8F9 0B6000913 lda mon_numwka+3
|
|
00FFF8FC 0B7000901 sta mon_DSAVE+1
|
|
00FFF8FF 016FFFA5A lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
SetRegD:
|
|
00FFF902 017FFFB75 lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF905 017FFFC89 lbsr GetNumber
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF908 0FC000912 ldd mon_numwka+2
|
|
00FFF90B 0FD000900 std mon_DSAVE
|
|
00FFF90E 016FFFA4B lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
SetRegX:
|
|
00FFF911 017FFFB66 lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF914 017FFFC7A lbsr GetNumber
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF917 0FC000912 ldd mon_numwka+2
|
|
00FFF91A 0FD000902 std mon_XSAVE
|
|
00FFF91D 016FFFA3C lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
SetRegY:
|
|
00FFF920 017FFFB57 lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF923 017FFFC6B lbsr GetNumber
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF926 0FC000912 ldd mon_numwka+2
|
|
00FFF929 0FD000904 std mon_YSAVE
|
|
00FFF92C 016FFFA2D lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
SetRegU:
|
|
00FFF92F 017FFFB48 lbsr ignBlanks
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF550 08DF2D bsr nXBLANK
|
00FFF932 017FFFC5C lbsr GetNumber
|
00FFF552 0FC000900 ldd mon_DSAVE
|
|
00FFF555 08DF24 bsr nHEX4
|
|
00FFF557 08DF26 bsr nXBLANK
|
|
00FFF559 0FC000902 ldd mon_XSAVE
|
|
00FFF55C 08DF1D bsr nHEX4
|
|
00FFF55E 08DF1F bsr nXBLANK
|
|
00FFF560 0FC000904 ldd mon_YSAVE
|
|
00FFF563 08DF16 bsr nHEX4
|
|
00FFF565 08DF18 bsr nXBLANK
|
|
00FFF567 0FC000906 ldd mon_USAVE
|
|
00FFF56A 08DF0F bsr nHEX4
|
|
00FFF56C 08DF11 bsr nXBLANK
|
|
00FFF56E 0FC000908 ldd mon_SSAVE
|
|
00FFF571 08DF08 bsr nHEX4
|
|
00FFF573 08DF0A bsr nXBLANK
|
|
00FFF575 0F600090B ldb mon_PCSAVE+1
|
|
00FFF578 017FFEEBC lbsr DispByteAsHex
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF57B 0FC00090C ldd mon_PCSAVE+2
|
|
00FFF57E 08DEFB bsr nHEX4
|
|
00FFF580 08DEFD bsr nXBLANK
|
|
00FFF582 0FC00090E ldd mon_DPRSAVE
|
|
00FFF585 0BDFFD2CE jsr HEX2
|
|
00FFF588 08DEF5 bsr nXBLANK
|
|
00FFF58A 0B600090F lda mon_CCRSAVE
|
|
00FFF58D 017FFDD3E lbsr HEX2
|
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF590 08DEED bsr nXBLANK
|
00FFF935 0FC000912 ldd mon_numwka+2
|
00FFF592 016FFFAA4 lbra Monitor
|
00FFF938 0FD000906 std mon_USAVE
|
|
00FFF93B 016FFFA1E lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
SetRegS:
|
|
00FFF93E 017FFFB39 lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF941 017FFFC4D lbsr GetNumber
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF944 0FC000912 ldd mon_numwka+2
|
|
00FFF947 0FD000908 std mon_SSAVE
|
|
00FFF94A 016FFFA0F lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
SetRegDPR:
|
|
00FFF94D 017FFFB2A lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF950 017FFFC3E lbsr GetNumber
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF953 0B6000913 lda mon_numwka+3
|
|
00FFF956 0B700090E sta mon_DPRSAVE
|
|
00FFF959 016FFFA00 lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
SetRegCCR:
|
|
00FFF95C 017FFFB1B lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF95F 017FFFC2F lbsr GetNumber
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF962 0B6000913 lda mon_numwka+3
|
|
00FFF965 0B700090F sta mon_CCRSAVE
|
|
00FFF968 016FFF9F1 lbra Monitor
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
SetRegPC:
|
|
00FFF96B 017FFFB0C lbsr ignBlanks
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF96E 017FFFC20 lbsr GetNumber
|
|
*** warning 1: Long branch within short branch range could be optimized
|
|
00FFF971 0FC000912 ldd mon_numwka+2
|
|
00FFF974 0FD00090C std mon_PCSAVE+2
|
|
00FFF977 0F6000911 ldb mon_numwka+1
|
|
00FFF97A 0F700090B stb mon_PCSAVE+1
|
|
00FFF97D 016FFF9DC lbra Monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; Jump to code
|
; Jump to code
|
;
|
;
|
Line 4028... |
Line 4728... |
;
|
;
|
; J
|
; J
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
jump_to_code:
|
jump_to_code:
|
00FFF595 08DCCB bsr GetNumber
|
00FFF980 017FFFAF7 lbsr ignBlanks
|
00FFF597 01A010 sei
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF599 1FE000908 lds mon_SSAVE
|
00FFF983 017FFFC0B lbsr GetNumber
|
00FFF59C 0CCFFF5D0 ldd #jtc_exit ; setup stack for RTS back to monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF59F 034006 pshs d
|
00FFF986 01A010 sei
|
00FFF5A1 0C6000 ldb #0
|
00FFF988 1FE000908 lds mon_SSAVE
|
00FFF5A3 034004 pshs b
|
00FFF98B 0CCFFF9BA ldd #jtc_exit ; setup stack for RTS back to monitor
|
00FFF5A5 0FC000912 ldd mon_numwka+2 ; get the address parameter
|
00FFF98E 034006 pshs d
|
00FFF5A8 034006 pshs d
|
00FFF990 0C6000 ldb #0
|
00FFF5AA 0F6000911 ldb mon_numwka+1
|
00FFF992 034004 pshs b
|
00FFF5AD 034004 pshs b
|
00FFF994 0FC000906 ldd mon_USAVE
|
00FFF5AF 0FC000906 ldd mon_USAVE
|
00FFF997 034006 pshs d
|
00FFF5B2 034006 pshs d
|
00FFF999 0FC000904 ldd mon_YSAVE
|
00FFF5B4 0FC000904 ldd mon_YSAVE
|
00FFF99C 034006 pshs d
|
00FFF5B7 034006 pshs d
|
00FFF99E 0FC000902 ldd mon_XSAVE
|
00FFF5B9 0FC000902 ldd mon_XSAVE
|
00FFF9A1 034006 pshs d
|
00FFF5BC 034006 pshs d
|
00FFF9A3 0B600090E lda mon_DPRSAVE
|
00FFF5BE 0B600090E lda mon_DPRSAVE
|
00FFF9A6 034002 pshs a
|
00FFF5C1 034002 pshs a
|
00FFF9A8 0FC000900 ldd mon_DSAVE
|
00FFF5C3 0FC000900 ldd mon_DSAVE
|
00FFF9AB 034006 pshs d
|
00FFF5C6 034006 pshs d
|
00FFF9AD 0B600090F lda mon_CCRSAVE
|
00FFF5C8 0B600090F lda mon_CCRSAVE
|
00FFF9B0 034002 pshs a
|
00FFF5CB 034002 pshs a
|
00FFF9B2 01503507F puls far ccr,d,dpr,x,y,u
|
00FFF5CD 0150350FF puls far ccr,d,dpr,x,y,u,pc
|
00FFF9B5 01506E90F000911 jmp far [mon_numwka+1]
|
jtc_exit:
|
jtc_exit:
|
00FFF5D0 1FF000908 sts >mon_SSAVE ; need to use extended addressing, no direct page setting
|
00FFF9BA 1FF000908 sts >mon_SSAVE ; need to use extended addressing, no direct page setting
|
00FFF5D3 03280F006FFF leas $6FFF ; reset stack to system area, dont modify flags register!
|
00FFF9BD 03280F006FFF leas $6FFF ; reset stack to system area, dont modify flags register!
|
00FFF5D7 034001 pshs ccr ; now the stack can be used
|
00FFF9C1 034001 pshs ccr ; now the stack can be used
|
00FFF5D9 034002 pshs a ; save acca register so we can use it
|
00FFF9C3 034002 pshs a ; save acca register so we can use it
|
00FFF5DB 01F0B8 tfr dpr,a ; a = outgoing dpr value
|
00FFF9C5 01F0B8 tfr dpr,a ; a = outgoing dpr value
|
00FFF5DD 0B700090E sta >mon_DPRSAVE ; force extended addressing mode usage here dpr is not set
|
00FFF9C7 0B700090E sta >mon_DPRSAVE ; force extended addressing mode usage here dpr is not set
|
00FFF5E0 04F clra ; dpg register must be set to zero before values are
|
00FFF9CA 04F clra ; dpg register must be set to zero before values are
|
00FFF5E1 01F08B tfr a,dpr ; saved in the monitor register save area.
|
00FFF9CB 01F08B tfr a,dpr ; saved in the monitor register save area.
|
00FFF5E3 035002 puls a ; get back acca
|
00FFF9CD 035002 puls a ; get back acca
|
00FFF5E5 0FD000900 std mon_DSAVE ; save regsters, can use direct addressing now
|
00FFF9CF 0FD000900 std mon_DSAVE ; save regsters, can use direct addressing now
|
00FFF5E8 0BF000902 stx mon_XSAVE
|
00FFF9D2 0BF000902 stx mon_XSAVE
|
00FFF5EB 1BF000904 sty mon_YSAVE
|
00FFF9D5 1BF000904 sty mon_YSAVE
|
00FFF5EE 0FF000906 stu mon_USAVE
|
00FFF9D8 0FF000906 stu mon_USAVE
|
00FFF5F1 035002 puls a ; get back ccr
|
00FFF9DB 035002 puls a ; get back ccr
|
00FFF5F3 0B700090F sta mon_CCRSAVE ; and save it too
|
00FFF9DD 0B700090F sta mon_CCRSAVE ; and save it too
|
; Reset vectors in case they got toasted.
|
; Reset vectors in case they got toasted.
|
00FFF5F6 0CCFFEC64 ldd #SerialPeekCharDirect
|
00FFF9E0 0CCFFEC73 ldd #SerialPeekCharDirect
|
00FFF5F9 0FD000804 std CharInVec
|
00FFF9E3 0FD000804 std CharInVec
|
00FFF5FC 0CCFFE319 ldd #DisplayChar
|
00FFF9E6 0CCFFE31C ldd #DisplayChar
|
00FFF5FF 0FD000800 std CharOutVec
|
00FFF9E9 0FD000800 std CharOutVec
|
00FFF602 0FCFFF2B6 ldd DisplayErr
|
00FFF9EC 0FCFFF5E5 ldd DisplayErr
|
00FFF605 0FD00080C std MonErrVec
|
00FFF9EF 0FD00080C std MonErrVec
|
; todo set according to coreid
|
; todo set according to coreid
|
00FFF608 016FFFF3F lbra DumpRegs ; now go do a register dump
|
00FFF9F2 016FFFEA4 lbra DumpRegs ; now go do a register dump
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
DumpIOFocusList:
|
DumpIOFocusList:
|
00FFF60B 08E000000 ldx #0
|
00FFF9F5 08E000000 ldx #0
|
dfl2:
|
dfl2:
|
00FFF60E 0E680A000FFC000 ldb IOFocusList,x
|
00FFF9F8 0E680A000FFC000 ldb IOFocusList,x
|
00FFF613 0C1018 cmpb #24
|
00FFF9FD 0C1018 cmpb #24
|
00FFF615 02600A bne dfl1
|
00FFF9FF 02600A bne dfl1
|
00FFF617 01F010 tfr x,d
|
00FFFA01 01F010 tfr x,d
|
00FFF619 017FFEE1B lbsr DispByteAsHex
|
00FFFA03 017FFEA34 lbsr DispByteAsHex
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF61C 0C6020 ldb #' '
|
00FFFA06 0C6020 ldb #' '
|
00FFF61E 017FFF8C0 lbsr OUTCH
|
00FFFA08 017FFF7BE lbsr OUTCH
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
dfl1:
|
dfl1:
|
00FFF621 030001 inx
|
00FFFA0B 030001 inx
|
00FFF623 08C000010 cmpx #16
|
00FFFA0D 08C000010 cmpx #16
|
00FFF626 025FE6 blo dfl2
|
00FFFA10 025FE6 blo dfl2
|
00FFF628 017FFDAA7 lbsr CRLF
|
00FFFA12 017FFD6BD lbsr CRLF
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF62B 016FFFA0B lbra Monitor
|
00FFFA15 016FFF944 lbra Monitor
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
|
|
bootpg:
|
bootpg:
|
00FFF62E 000 fcb $000
|
00FFFA18 000 fcb $000
|
boot_stack:
|
boot_stack:
|
00FFF62F FFC0FF fcw $FFC0FF
|
00FFFA19 FFC0FF fcw $FFC0FF
|
numBreakpoints:
|
numBreakpoints:
|
00FFF631 008 fcb 8
|
00FFFA1B 000008 fcw 8
|
mon_rom_vectab:
|
mon_rom_vectab:
|
00FFF632 FFF634 fcw mon_rom_vecs
|
00FFFA1D FFFA1F fcw mon_rom_vecs
|
mon_rom_vecs:
|
mon_rom_vecs:
|
00FFF634 FFF039 fcw Monitor ; enter monitor program
|
00FFFA1F FFF35C fcw Monitor ; enter monitor program
|
00FFF636 FFEEA9 fcw INCH ; input a character
|
00FFFA21 FFF191 fcw INCH ; input a character
|
00FFF638 FFEEE1 fcw OUTCH ; output a character
|
00FFFA23 FFF1C9 fcw OUTCH ; output a character
|
00FFF63A FFD0D2 fcw CRLF ; output carriage-return, line feed
|
00FFFA25 FFD0D2 fcw CRLF ; output carriage-return, line feed
|
00FFF63C FFE3DA fcw DisplayString
|
00FFFA27 FFE3DD fcw DisplayString
|
00FFF63E FFE437 fcw DispByteAsHex
|
00FFFA29 FFE43A fcw DispByteAsHex
|
00FFF640 FFE42E fcw DispWordAsHex
|
00FFFA2B FFE431 fcw DispWordAsHex
|
00FFF642 FFEEEB fcw ShowSprites
|
00FFFA2D FFF1D3 fcw ShowSprites
|
00FFF644 FFEF6F fcw mon_srand
|
00FFFA2F FFF257 fcw mon_srand
|
00FFF646 FFEF9D fcw mon_rand
|
00FFFA31 FFF285 fcw mon_rand
|
00FFF648 000000 fcw 0 ; operating system call
|
00FFFA33 000000 fcw 0 ; operating system call
|
00FFF64A FFF1A3 fcw GetRange
|
00FFFA35 FFF4D2 fcw GetRange
|
00FFF64C FFF262 fcw GetNumber
|
00FFFA37 FFF591 fcw GetNumber
|
|
00FFFA39 FFEC9A fcw SerialPutChar
|
|
|
NumFuncs EQU (*-mon_rom_vectab)/2
|
NumFuncs EQU (*-mon_rom_vectab)/2
|
|
|
; The following table indicates which routines need to return values in the
|
; The following table indicates which routines need to return values in the
|
; D and possibly X registers.
|
; D and possibly X registers.
|
|
|
mon_rettab:
|
mon_rettab:
|
00FFF64E 000 fcb 0 ; monitor
|
00FFFA3B 000 fcb 0 ; monitor
|
00FFF64F 800 fcb $800 ; INCH
|
00FFFA3C 800 fcb $800 ; INCH
|
00FFF650 000 fcb 0 ; OUTCH
|
00FFFA3D 000 fcb 0 ; OUTCH
|
00FFF651 000 fcb 0 ; CRLF
|
00FFFA3E 000 fcb 0 ; CRLF
|
00FFF652 000 fcb 0 ; DisplayString
|
00FFFA3F 000 fcb 0 ; DisplayString
|
00FFF653 000 fcb 0 ; DisplayByte
|
00FFFA40 000 fcb 0 ; DisplayByte
|
00FFF654 000 fcb 0 ; DisplayWord
|
00FFFA41 000 fcb 0 ; DisplayWord
|
00FFF655 000 fcb 0 ; show sprites
|
00FFFA42 000 fcb 0 ; show sprites
|
00FFF656 000 fcb 0 ; srand
|
00FFFA43 000 fcb 0 ; srand
|
00FFF657 C00 fcb $C00 ; rand
|
00FFFA44 C00 fcb $C00 ; rand
|
00FFF658 C00 fcb $C00 ; OS call
|
00FFFA45 C00 fcb $C00 ; OS call
|
00FFF659 000 fcb 0 ; GetRange
|
00FFFA46 000 fcb 0 ; GetRange
|
00FFF65A 800 fcb $800 ; GetNumber
|
00FFFA47 800 fcb $800 ; GetNumber
|
|
00FFFA48 000 fcb 0 ; SerialPutChar
|
|
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
; SWI routine.
|
; SWI routine.
|
;
|
;
|
; SWI is used to call ROM monitor routines and process breakpoints.
|
; SWI is used to call ROM monitor routines and process breakpoints.
|
Line 4156... |
Line 4858... |
; swi
|
; swi
|
; fcb
|
; fcb
|
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
|
|
swi_rout:
|
swi_rout:
|
00FFF65B 0E680CFD0 ldb bootpg,pcr ; reset direct page
|
00FFFA49 0E680CFCC ldb bootpg,pcr ; reset direct page
|
00FFF65E 01F09B tfr b,dp
|
00FFFA4C 01F09B tfr b,dp
|
swi_rout1:
|
swi_rout1:
|
00FFF660 0EE60B ldu 11,s ; get program counter (low order 2 bytes)
|
00FFFA4E 0EE60B ldu 11,s ; get program counter (low order 2 bytes)
|
00FFF662 0335FF leau -1,u ; backup a byte
|
00FFFA50 0335FF leau -1,u ; backup a byte
|
00FFF664 07D000810 tst BreakpointFlag ; are we in breakpoint mode?
|
00FFFA52 07D000810 tst BreakpointFlag ; are we in breakpoint mode?
|
00FFF667 02700F beq swiNotBkpt
|
00FFFA55 02700F beq swiNotBkpt
|
00FFF669 0CE000820 ldu #Breakpoints
|
00FFFA57 18E000820 ldy #Breakpoints
|
00FFF66C 0F6000811 ldb NumSetBreakpoints
|
00FFFA5A 0F6000811 ldb NumSetBreakpoints
|
00FFF66F 027007 beq swiNotBkpt
|
00FFFA5D 027007 beq swiNotBkpt
|
swi_rout2:
|
swi_rout2:
|
00FFF671 2A3A01 cmpu ,y++
|
00FFFA5F 2A3A01 cmpu ,y++
|
00FFF673 02704B beq processBreakpoint
|
00FFFA61 02704B beq processBreakpoint
|
00FFF675 05A decb
|
00FFFA63 05A decb
|
00FFF676 026FF9 bne swi_rout2
|
00FFFA64 026FF9 bne swi_rout2
|
swiNotBkpt:
|
swiNotBkpt:
|
00FFF678 07F000810 clr BreakpointFlag
|
00FFFA66 07F000810 clr BreakpointFlag
|
00FFF67B 037006 pulu d ; get function #, increment PC
|
00FFFA69 037006 pulu d ; get function #, increment PC
|
00FFF67D 0C100E cmpb #NumFuncs
|
00FFFA6B 0C100F cmpb #NumFuncs
|
00FFF67F 122FFFC34 lbhi DisplayErr
|
00FFFA6D 122FFFB75 lbhi DisplayErr
|
*** warning 1: Long branch within short branch range could be optimized
|
*** warning 1: Long branch within short branch range could be optimized
|
00FFF682 0EF60B stu 11,s ; save updated PC on stack
|
00FFFA70 0EF60B stu 11,s ; save updated PC on stack
|
00FFF684 0C100A cmpb #MF_OSCALL
|
00FFFA72 0C100A cmpb #MF_OSCALL
|
00FFF686 02706D beq swiCallOS
|
00FFFA74 027072 beq swiCallOS
|
00FFF688 058 aslb ; 2 bytes per vector
|
00FFFA76 058 aslb ; 2 bytes per vector
|
00FFF689 0AE80CFA6 ldx mon_rom_vectab,pcr
|
00FFFA77 0AE80CFA3 ldx mon_rom_vectab,pcr
|
00FFF68C 03A abx
|
00FFFA7A 03A abx
|
00FFF68D 0AE804 ldx ,x
|
00FFFA7B 0AE804 ldx ,x
|
00FFF68F 0BF000928 stx jmpvec
|
00FFFA7D 0BF000928 stx jmpvec
|
00FFF692 054 lsrb
|
00FFFA80 054 lsrb
|
00FFF693 08EFFF64E ldx #mon_rettab
|
00FFFA81 08EFFFA3B ldx #mon_rettab
|
00FFF696 03A abx
|
00FFFA84 03A abx
|
00FFF697 0E6804 ldb ,x
|
00FFFA85 0E6804 ldb ,x
|
00FFF699 0F7000930 stb mon_retflag
|
00FFFA87 0F7000930 stb mon_retflag
|
00FFF69C 1FF000908 sts mon_SSAVE ; save the stack pointer
|
00FFFA8A 1FF000908 sts mon_SSAVE ; save the stack pointer
|
00FFF69F 0EC601 ldd 1,s ; get back D
|
00FFFA8D 0EC601 ldd 1,s ; get back D
|
00FFF6A1 0AE604 ldx 4,s ; get back X
|
00FFFA8F 0AE604 ldx 4,s ; get back X
|
00FFF6A3 1AE606 ldy 6,s ; get back Y
|
00FFFA91 1AE606 ldy 6,s ; get back Y
|
00FFF6A5 0EE608 ldu 8,s ; get back U
|
|