forked from Apple-2-HW/Apple2-IO-RPi
Update RPi.Command and driver for it
This commit is contained in:
parent
707c704119
commit
55d94dd1f0
@ -42,6 +42,13 @@ SlotL = $fe
|
|||||||
SlotH = $ff
|
SlotH = $ff
|
||||||
ESC = $9b
|
ESC = $9b
|
||||||
|
|
||||||
|
;macro for string with high-bit set
|
||||||
|
.macro aschi str
|
||||||
|
.repeat .strlen (str), c
|
||||||
|
.byte .strat (str, c) | $80
|
||||||
|
.endrep
|
||||||
|
.endmacro
|
||||||
|
|
||||||
.org $2000
|
.org $2000
|
||||||
ldx #$07 ; start at slot 7
|
ldx #$07 ; start at slot 7
|
||||||
DetectSlot:
|
DetectSlot:
|
||||||
@ -78,21 +85,22 @@ nextSlot:
|
|||||||
rts
|
rts
|
||||||
Start:
|
Start:
|
||||||
stx slotx + $1e01 ;set the slot for the driver
|
stx slotx + $1e01 ;set the slot for the driver
|
||||||
ldx #$00
|
ldy #$00
|
||||||
|
PrintString:
|
||||||
|
lda Text,y
|
||||||
|
beq copyDriver
|
||||||
|
ora #$80
|
||||||
|
jsr PrintChar
|
||||||
|
iny
|
||||||
|
bne PrintString
|
||||||
copyDriver:
|
copyDriver:
|
||||||
|
ldx #$00
|
||||||
|
copyDriverByte:
|
||||||
lda $2100,x
|
lda $2100,x
|
||||||
sta $0300,x
|
sta $0300,x
|
||||||
inx
|
inx
|
||||||
cpx #$e6
|
cpx #$e6
|
||||||
bne copyDriver
|
bne copyDriverByte
|
||||||
end:
|
|
||||||
jmp $0300
|
|
||||||
|
|
||||||
.repeat 253-<end
|
|
||||||
.byte 0
|
|
||||||
.endrepeat
|
|
||||||
|
|
||||||
.org $0300
|
|
||||||
;
|
;
|
||||||
; FIRST SAVE THE EXTERNAL COMMAND ADDRESS SO YOU WON'T
|
; FIRST SAVE THE EXTERNAL COMMAND ADDRESS SO YOU WON'T
|
||||||
; DISCONNECT ANY PREVIOUSLY CONNECTED COMMAND.
|
; DISCONNECT ANY PREVIOUSLY CONNECTED COMMAND.
|
||||||
@ -108,6 +116,18 @@ end:
|
|||||||
STA EXTRNCMD+2 ; vector.
|
STA EXTRNCMD+2 ; vector.
|
||||||
RTS
|
RTS
|
||||||
;
|
;
|
||||||
|
|
||||||
|
Text:
|
||||||
|
aschi "RPI command v000D"
|
||||||
|
.byte $8d
|
||||||
|
end:
|
||||||
|
.byte $00
|
||||||
|
|
||||||
|
.repeat 255-<end
|
||||||
|
.byte 0
|
||||||
|
.endrepeat
|
||||||
|
|
||||||
|
.org $0300
|
||||||
RPI: LDX #0 ;Check for our command.
|
RPI: LDX #0 ;Check for our command.
|
||||||
NXTCHR: LDA INBUF,X ;Get first character.
|
NXTCHR: LDA INBUF,X ;Get first character.
|
||||||
ora #$20 ;Make it lower case
|
ora #$20 ;Make it lower case
|
||||||
@ -159,18 +179,9 @@ sendNullTerminator:
|
|||||||
jsr SendByte
|
jsr SendByte
|
||||||
DumpOutput:
|
DumpOutput:
|
||||||
jsr GetByte
|
jsr GetByte
|
||||||
bcs skipOutput
|
|
||||||
cmp #$00
|
cmp #$00
|
||||||
beq endOutput
|
beq endOutput
|
||||||
jsr PrintChar
|
jsr PrintChar
|
||||||
skipOutput:
|
|
||||||
bit Keyboard ;check for keypress
|
|
||||||
bpl DumpOutput ;keep dumping output if no keypress
|
|
||||||
lda Keyboard ;send keypress to RPi
|
|
||||||
jsr PrintChar
|
|
||||||
and #$7f
|
|
||||||
jsr SendByte
|
|
||||||
bit ClearKeyboard
|
|
||||||
clc
|
clc
|
||||||
bcc DumpOutput
|
bcc DumpOutput
|
||||||
endOutput:
|
endOutput:
|
||||||
@ -206,13 +217,7 @@ GetByte:
|
|||||||
waitRead:
|
waitRead:
|
||||||
lda InputFlags,x
|
lda InputFlags,x
|
||||||
rol
|
rol
|
||||||
bcc readByte
|
bcs waitRead
|
||||||
bit Keyboard ;keypress will abort waiting to read
|
|
||||||
bpl waitRead
|
|
||||||
lda #$1f ;set all flags high and exit
|
|
||||||
sta OutputFlags,x
|
|
||||||
sec ;failure
|
|
||||||
rts
|
|
||||||
readByte:
|
readByte:
|
||||||
lda InputByte,x
|
lda InputByte,x
|
||||||
pha
|
pha
|
||||||
@ -227,13 +232,6 @@ finishRead:
|
|||||||
rts
|
rts
|
||||||
|
|
||||||
|
|
||||||
;macro for string with high-bit set
|
|
||||||
.macro aschi str
|
|
||||||
.repeat .strlen (str), c
|
|
||||||
.byte .strat (str, c) | $80
|
|
||||||
.endrep
|
|
||||||
.endmacro
|
|
||||||
|
|
||||||
CMD: aschi "rpi"
|
CMD: aschi "rpi"
|
||||||
CMDLEN = 3 ;Our command length
|
CMDLEN = 3 ;Our command length
|
||||||
;
|
;
|
||||||
|
Binary file not shown.
@ -46,6 +46,13 @@ Current file: RPi.Command.asm
|
|||||||
000300 1 SlotH = $ff
|
000300 1 SlotH = $ff
|
||||||
000300 1 ESC = $9b
|
000300 1 ESC = $9b
|
||||||
000300 1
|
000300 1
|
||||||
|
000300 1 ;macro for string with high-bit set
|
||||||
|
000300 1 .macro aschi str
|
||||||
|
000300 1 .repeat .strlen (str), c
|
||||||
|
000300 1 .byte .strat (str, c) | $80
|
||||||
|
000300 1 .endrep
|
||||||
|
000300 1 .endmacro
|
||||||
|
000300 1
|
||||||
000300 1 .org $2000
|
000300 1 .org $2000
|
||||||
002000 1 A2 07 ldx #$07 ; start at slot 7
|
002000 1 A2 07 ldx #$07 ; start at slot 7
|
||||||
002002 1 DetectSlot:
|
002002 1 DetectSlot:
|
||||||
@ -81,171 +88,164 @@ Current file: RPi.Command.asm
|
|||||||
00202E 1 D0 D2 bne DetectSlot
|
00202E 1 D0 D2 bne DetectSlot
|
||||||
002030 1 60 rts
|
002030 1 60 rts
|
||||||
002031 1 Start:
|
002031 1 Start:
|
||||||
002031 1 8E 48 21 stx slotx + $1e01 ;set the slot for the driver
|
002031 1 8E 31 21 stx slotx + $1e01 ;set the slot for the driver
|
||||||
002034 1 A2 00 ldx #$00
|
002034 1 A0 00 ldy #$00
|
||||||
002036 1 copyDriver:
|
002036 1 PrintString:
|
||||||
002036 1 BD 00 21 lda $2100,x
|
002036 1 B9 67 20 lda Text,y
|
||||||
002039 1 9D 00 03 sta $0300,x
|
002039 1 F0 08 beq copyDriver
|
||||||
00203C 1 E8 inx
|
00203B 1 09 80 ora #$80
|
||||||
00203D 1 E0 E6 cpx #$e6
|
00203D 1 20 ED FD jsr PrintChar
|
||||||
00203F 1 D0 F5 bne copyDriver
|
002040 1 C8 iny
|
||||||
002041 1 end:
|
002041 1 D0 F3 bne PrintString
|
||||||
002041 1 4C 00 03 jmp $0300
|
002043 1 copyDriver:
|
||||||
002044 1
|
002043 1 A2 00 ldx #$00
|
||||||
002044 1 00 00 00 00 .repeat 253-<end
|
002045 1 copyDriverByte:
|
||||||
002048 1 00 00 00 00
|
002045 1 BD 00 21 lda $2100,x
|
||||||
00204C 1 00 00 00 00
|
002048 1 9D 00 03 sta $0300,x
|
||||||
|
00204B 1 E8 inx
|
||||||
|
00204C 1 E0 E6 cpx #$e6
|
||||||
|
00204E 1 D0 F5 bne copyDriverByte
|
||||||
|
002050 1 ;
|
||||||
|
002050 1 ; FIRST SAVE THE EXTERNAL COMMAND ADDRESS SO YOU WON'T
|
||||||
|
002050 1 ; DISCONNECT ANY PREVIOUSLY CONNECTED COMMAND.
|
||||||
|
002050 1 ;
|
||||||
|
002050 1 AD 07 BE LDA EXTRNCMD+1
|
||||||
|
002053 1 8D AD 03 STA NXTCMD
|
||||||
|
002056 1 AD 08 BE LDA EXTRNCMD+2
|
||||||
|
002059 1 8D AE 03 STA NXTCMD+1
|
||||||
|
00205C 1 ;
|
||||||
|
00205C 1 A9 00 LDA #<RPI ;Install the address of our
|
||||||
|
00205E 1 8D 07 BE STA EXTRNCMD+1 ; command handler in the
|
||||||
|
002061 1 A9 03 LDA #>RPI ; external command JMP
|
||||||
|
002063 1 8D 08 BE STA EXTRNCMD+2 ; vector.
|
||||||
|
002066 1 60 RTS
|
||||||
|
002067 1 ;
|
||||||
|
002067 1
|
||||||
|
002067 1 Text:
|
||||||
|
002067 1 D2 D0 C9 A0 aschi "RPI command v000D"
|
||||||
|
00206B 1 E3 EF ED ED
|
||||||
|
00206F 1 E1 EE E4 A0
|
||||||
|
002078 1 8D .byte $8d
|
||||||
|
002079 1 end:
|
||||||
|
002079 1 00 .byte $00
|
||||||
|
00207A 1
|
||||||
|
00207A 1 00 00 00 00 .repeat 255-<end
|
||||||
|
00207E 1 00 00 00 00
|
||||||
|
002082 1 00 00 00 00
|
||||||
002100 1 .byte 0
|
002100 1 .byte 0
|
||||||
002100 1 .endrepeat
|
002100 1 .endrepeat
|
||||||
002100 1
|
002100 1
|
||||||
002100 1 .org $0300
|
002100 1 .org $0300
|
||||||
000300 1 ;
|
000300 1 A2 00 RPI: LDX #0 ;Check for our command.
|
||||||
000300 1 ; FIRST SAVE THE EXTERNAL COMMAND ADDRESS SO YOU WON'T
|
000302 1 BD 00 02 NXTCHR: LDA INBUF,X ;Get first character.
|
||||||
000300 1 ; DISCONNECT ANY PREVIOUSLY CONNECTED COMMAND.
|
000305 1 09 20 ora #$20 ;Make it lower case
|
||||||
000300 1 ;
|
000307 1 DD AA 03 CMP CMD,X ;Does it match?
|
||||||
000300 1 AD 07 BE LDA EXTRNCMD+1
|
00030A 1 D0 29 BNE NOTOURS ;No, back to CI.
|
||||||
000303 1 8D E5 03 STA NXTCMD
|
00030C 1 E8 INX ;Next character
|
||||||
000306 1 AD 08 BE LDA EXTRNCMD+2
|
00030D 1 E0 03 CPX #CMDLEN ;All characters yet?
|
||||||
000309 1 8D E6 03 STA NXTCMD+1
|
00030F 1 D0 F1 BNE NXTCHR ;No, read next one.
|
||||||
00030C 1 ;
|
000311 1 ;
|
||||||
00030C 1 A9 17 LDA #<RPI ;Install the address of our
|
000311 1 A9 02 LDA #CMDLEN-1 ;Our cmd! Put cmd length-1
|
||||||
00030E 1 8D 07 BE STA EXTRNCMD+1 ; command handler in the
|
000313 1 ;lda #$8d
|
||||||
000311 1 A9 03 LDA #>RPI ; external command JMP
|
000313 1 ;sta $02ff
|
||||||
000313 1 8D 08 BE STA EXTRNCMD+2 ; vector.
|
000313 1 ;lda #$fe
|
||||||
000316 1 60 RTS
|
000313 1 8D 52 BE STA XLEN ; in CI global XLEN.
|
||||||
000317 1 ;
|
000316 1 A9 58 LDA #<XRETURN ;Point XTRNADDR to a known
|
||||||
000317 1 A2 00 RPI: LDX #0 ;Check for our command.
|
000318 1 8D 50 BE STA XTRNADDR ; RTS since we'll handle
|
||||||
000319 1 BD 00 02 NXTCHR: LDA INBUF,X ;Get first character.
|
00031B 1 A9 FF LDA #>XRETURN ; at the time we intercept
|
||||||
00031C 1 09 20 ora #$20 ;Make it lower case
|
00031D 1
|
||||||
00031E 1 DD E2 03 CMP CMD,X ;Does it match?
|
00031D 1 8D 51 BE STA XTRNADDR+1 ; our command.
|
||||||
000321 1 D0 29 BNE NOTOURS ;No, back to CI.
|
000320 1 A9 00 LDA #0 ;Mark the cmd number as
|
||||||
000323 1 E8 INX ;Next character
|
000322 1 8D 53 BE STA XCNUM ; zero (external).
|
||||||
000324 1 E0 03 CPX #CMDLEN ;All characters yet?
|
000325 1 8D 54 BE STA PBITS ;And indicate no parameters
|
||||||
000326 1 D0 F1 BNE NXTCHR ;No, read next one.
|
000328 1 8D 55 BE STA PBITS+1 ; to be parsed.
|
||||||
000328 1 ;
|
00032B 1 A9 8D lda #$8d
|
||||||
000328 1 A9 02 LDA #CMDLEN-1 ;Our cmd! Put cmd length-1
|
00032D 1 20 ED FD jsr $fded
|
||||||
00032A 1 ;lda #$8d
|
000330 1 A2 70 slotx: ldx #$70 ; set x to slot # in high nibble
|
||||||
00032A 1 ;sta $02ff
|
000332 1 18 clc
|
||||||
00032A 1 ;lda #$fe
|
000333 1 90 04 bcc SendCommand
|
||||||
00032A 1 8D 52 BE STA XLEN ; in CI global XLEN.
|
000335 1 ;
|
||||||
00032D 1 A9 58 LDA #<XRETURN ;Point XTRNADDR to a known
|
000335 1 38 NOTOURS: SEC ; ALWAYS SET CARRY IF NOT YOUR
|
||||||
00032F 1 8D 50 BE STA XTRNADDR ; RTS since we'll handle
|
000336 1 6C AD 03 JMP (NXTCMD) ; CMD AND LET NEXT COMMAND TRY
|
||||||
000332 1 A9 FF LDA #>XRETURN ; at the time we intercept
|
000339 1 ; ; TO CLAIM IT.
|
||||||
000334 1
|
000339 1
|
||||||
000334 1 8D 51 BE STA XTRNADDR+1 ; our command.
|
000339 1 SendCommand:
|
||||||
000337 1 A9 00 LDA #0 ;Mark the cmd number as
|
000339 1 2C 10 C0 bit ClearKeyboard
|
||||||
000339 1 8D 53 BE STA XCNUM ; zero (external).
|
00033C 1 A9 05 lda #$05 ;send command 5 = exec
|
||||||
00033C 1 8D 54 BE STA PBITS ;And indicate no parameters
|
00033E 1 20 6F 03 jsr SendByte
|
||||||
00033F 1 8D 55 BE STA PBITS+1 ; to be parsed.
|
000341 1 A0 03 ldy #$03 ;skip over "RPI"
|
||||||
000342 1 A9 8D lda #$8d
|
000343 1 getInput:
|
||||||
000344 1 20 ED FD jsr $fded
|
000343 1 B9 00 02 lda $0200,y
|
||||||
000347 1 A2 70 slotx: ldx #$70 ; set x to slot # in high nibble
|
000346 1 C9 8D cmp #$8d
|
||||||
000349 1 18 clc
|
000348 1 F0 08 beq sendNullTerminator
|
||||||
00034A 1 90 04 bcc SendCommand
|
00034A 1 29 7F and #$7f
|
||||||
00034C 1 ;
|
00034C 1 20 6F 03 jsr SendByte
|
||||||
00034C 1 38 NOTOURS: SEC ; ALWAYS SET CARRY IF NOT YOUR
|
00034F 1 C8 iny
|
||||||
00034D 1 6C E5 03 JMP (NXTCMD) ; CMD AND LET NEXT COMMAND TRY
|
000350 1 D0 F1 bne getInput
|
||||||
000350 1 ; ; TO CLAIM IT.
|
000352 1 sendNullTerminator:
|
||||||
000350 1
|
000352 1 A9 00 lda #$00
|
||||||
000350 1 SendCommand:
|
000354 1 20 6F 03 jsr SendByte
|
||||||
000350 1 2C 10 C0 bit ClearKeyboard
|
000357 1 DumpOutput:
|
||||||
000353 1 A9 05 lda #$05 ;send command 5 = exec
|
000357 1 20 8D 03 jsr GetByte
|
||||||
000355 1 20 9B 03 jsr SendByte
|
00035A 1 C9 00 cmp #$00
|
||||||
000358 1 A0 03 ldy #$03 ;skip over "RPI"
|
00035C 1 F0 06 beq endOutput
|
||||||
00035A 1 getInput:
|
00035E 1 20 ED FD jsr PrintChar
|
||||||
00035A 1 B9 00 02 lda $0200,y
|
000361 1 18 clc
|
||||||
00035D 1 C9 8D cmp #$8d
|
000362 1 90 F3 bcc DumpOutput
|
||||||
00035F 1 F0 08 beq sendNullTerminator
|
000364 1 endOutput:
|
||||||
000361 1 29 7F and #$7f
|
000364 1 18 clc
|
||||||
000363 1 20 9B 03 jsr SendByte
|
000365 1 6C AD 03 jmp (NXTCMD)
|
||||||
000366 1 C8 iny
|
000368 1
|
||||||
000367 1 D0 F1 bne getInput
|
000368 1 HelpCommand:
|
||||||
000369 1 sendNullTerminator:
|
000368 1 61 32 68 65 .byte "a2help",$00
|
||||||
000369 1 A9 00 lda #$00
|
00036C 1 6C 70 00
|
||||||
00036B 1 20 9B 03 jsr SendByte
|
00036F 1
|
||||||
00036E 1 DumpOutput:
|
00036F 1 SendByte:
|
||||||
00036E 1 20 B9 03 jsr GetByte
|
00036F 1 48 pha
|
||||||
000371 1 B0 07 bcs skipOutput
|
000370 1 waitWrite:
|
||||||
000373 1 C9 00 cmp #$00
|
000370 1 BD 8B C0 lda InputFlags,x
|
||||||
000375 1 F0 19 beq endOutput
|
000373 1 2A rol
|
||||||
000377 1 20 ED FD jsr PrintChar
|
000374 1 2A rol
|
||||||
00037A 1 skipOutput:
|
000375 1 B0 F9 bcs waitWrite
|
||||||
00037A 1 2C 00 C0 bit Keyboard ;check for keypress
|
000377 1 68 pla
|
||||||
00037D 1 10 EF bpl DumpOutput ;keep dumping output if no keypress
|
000378 1 9D 8D C0 sta OutputByte,x
|
||||||
00037F 1 AD 00 C0 lda Keyboard ;send keypress to RPi
|
00037B 1 A9 1E lda #$1e ; set bit 0 low to indicate write started
|
||||||
000382 1 20 ED FD jsr PrintChar
|
00037D 1 9D 87 C0 sta OutputFlags,x
|
||||||
000385 1 29 7F and #$7f
|
000380 1 finishWrite:
|
||||||
000387 1 20 9B 03 jsr SendByte
|
000380 1 BD 8B C0 lda InputFlags,x
|
||||||
00038A 1 2C 10 C0 bit ClearKeyboard
|
000383 1 2A rol
|
||||||
00038D 1 18 clc
|
000384 1 2A rol
|
||||||
00038E 1 90 DE bcc DumpOutput
|
000385 1 90 F9 bcc finishWrite
|
||||||
000390 1 endOutput:
|
000387 1 A9 1F lda #$1f
|
||||||
000390 1 18 clc
|
000389 1 9D 87 C0 sta OutputFlags,x
|
||||||
000391 1 6C E5 03 jmp (NXTCMD)
|
00038C 1 60 rts
|
||||||
000394 1
|
00038D 1
|
||||||
000394 1 HelpCommand:
|
00038D 1 GetByte:
|
||||||
000394 1 61 32 68 65 .byte "a2help",$00
|
00038D 1 A9 1D lda #$1d ;set read flag low
|
||||||
000398 1 6C 70 00
|
00038F 1 9D 87 C0 sta OutputFlags,x
|
||||||
00039B 1
|
000392 1 waitRead:
|
||||||
00039B 1 SendByte:
|
000392 1 BD 8B C0 lda InputFlags,x
|
||||||
|
000395 1 2A rol
|
||||||
|
000396 1 B0 FA bcs waitRead
|
||||||
|
000398 1 readByte:
|
||||||
|
000398 1 BD 8E C0 lda InputByte,x
|
||||||
00039B 1 48 pha
|
00039B 1 48 pha
|
||||||
00039C 1 waitWrite:
|
00039C 1 A9 1F lda #$1f ;set all flags high
|
||||||
00039C 1 BD 8B C0 lda InputFlags,x
|
00039E 1 9D 87 C0 sta OutputFlags,x
|
||||||
00039F 1 2A rol
|
0003A1 1 finishRead:
|
||||||
0003A0 1 2A rol
|
0003A1 1 BD 8B C0 lda InputFlags,x
|
||||||
0003A1 1 B0 F9 bcs waitWrite
|
0003A4 1 2A rol
|
||||||
0003A3 1 68 pla
|
0003A5 1 90 FA bcc finishRead
|
||||||
0003A4 1 9D 8D C0 sta OutputByte,x
|
0003A7 1 68 pla
|
||||||
0003A7 1 A9 1E lda #$1e ; set bit 0 low to indicate write started
|
0003A8 1 18 clc ;success
|
||||||
0003A9 1 9D 87 C0 sta OutputFlags,x
|
0003A9 1 60 rts
|
||||||
0003AC 1 finishWrite:
|
0003AA 1
|
||||||
0003AC 1 BD 8B C0 lda InputFlags,x
|
0003AA 1
|
||||||
0003AF 1 2A rol
|
0003AA 1 F2 F0 E9 CMD: aschi "rpi"
|
||||||
0003B0 1 2A rol
|
0003AD 1 CMDLEN = 3 ;Our command length
|
||||||
0003B1 1 90 F9 bcc finishWrite
|
0003AD 1 ;
|
||||||
0003B3 1 A9 1F lda #$1f
|
0003AD 1 00 00 NXTCMD: .byte 0,0 ; STORE THE NEXT EXT CMD'S
|
||||||
0003B5 1 9D 87 C0 sta OutputFlags,x
|
0003AF 1 ; ADDRESS HERE.
|
||||||
0003B8 1 60 rts
|
0003AF 1
|
||||||
0003B9 1
|
0003AF 1
|
||||||
0003B9 1 GetByte:
|
0003AF 1
|
||||||
0003B9 1 A9 1D lda #$1d ;set read flag low
|
|
||||||
0003BB 1 9D 87 C0 sta OutputFlags,x
|
|
||||||
0003BE 1 waitRead:
|
|
||||||
0003BE 1 BD 8B C0 lda InputFlags,x
|
|
||||||
0003C1 1 2A rol
|
|
||||||
0003C2 1 90 0C bcc readByte
|
|
||||||
0003C4 1 2C 00 C0 bit Keyboard ;keypress will abort waiting to read
|
|
||||||
0003C7 1 10 F5 bpl waitRead
|
|
||||||
0003C9 1 A9 1F lda #$1f ;set all flags high and exit
|
|
||||||
0003CB 1 9D 87 C0 sta OutputFlags,x
|
|
||||||
0003CE 1 38 sec ;failure
|
|
||||||
0003CF 1 60 rts
|
|
||||||
0003D0 1 readByte:
|
|
||||||
0003D0 1 BD 8E C0 lda InputByte,x
|
|
||||||
0003D3 1 48 pha
|
|
||||||
0003D4 1 A9 1F lda #$1f ;set all flags high
|
|
||||||
0003D6 1 9D 87 C0 sta OutputFlags,x
|
|
||||||
0003D9 1 finishRead:
|
|
||||||
0003D9 1 BD 8B C0 lda InputFlags,x
|
|
||||||
0003DC 1 2A rol
|
|
||||||
0003DD 1 90 FA bcc finishRead
|
|
||||||
0003DF 1 68 pla
|
|
||||||
0003E0 1 18 clc ;success
|
|
||||||
0003E1 1 60 rts
|
|
||||||
0003E2 1
|
|
||||||
0003E2 1
|
|
||||||
0003E2 1 ;macro for string with high-bit set
|
|
||||||
0003E2 1 .macro aschi str
|
|
||||||
0003E2 1 .repeat .strlen (str), c
|
|
||||||
0003E2 1 .byte .strat (str, c) | $80
|
|
||||||
0003E2 1 .endrep
|
|
||||||
0003E2 1 .endmacro
|
|
||||||
0003E2 1
|
|
||||||
0003E2 1 F2 F0 E9 CMD: aschi "rpi"
|
|
||||||
0003E5 1 CMDLEN = 3 ;Our command length
|
|
||||||
0003E5 1 ;
|
|
||||||
0003E5 1 00 00 NXTCMD: .byte 0,0 ; STORE THE NEXT EXT CMD'S
|
|
||||||
0003E7 1 ; ADDRESS HERE.
|
|
||||||
0003E7 1
|
|
||||||
0003E7 1
|
|
||||||
0003E7 1
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
ca65 V2.18 - N/A
|
ca65 V2.18 - Raspbian 2.19-1
|
||||||
Main file : Shell.asm
|
Main file : Shell.asm
|
||||||
Current file: Shell.asm
|
Current file: Shell.asm
|
||||||
|
|
||||||
|
Binary file not shown.
@ -10,15 +10,17 @@ package handlers
|
|||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/tjboldt/Apple2-IO-RPi/RaspberryPi/apple2driver/info"
|
"github.com/tjboldt/Apple2-IO-RPi/RaspberryPi/apple2driver/info"
|
||||||
)
|
)
|
||||||
|
|
||||||
var forceLowercase = false
|
var forceLowercase = false
|
||||||
|
var execTimeoutSeconds = int(10)
|
||||||
|
|
||||||
// ExecCommand handles requests for the Apple II executing Linux commands
|
// ExecCommand handles requests for the Apple II executing Linux commands
|
||||||
func ExecCommand() {
|
func ExecCommand() {
|
||||||
@ -68,6 +70,10 @@ func ExecCommand() {
|
|||||||
a2wifi()
|
a2wifi()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
if strings.HasPrefix(linuxCommand, "a2timeout") {
|
||||||
|
a2timeout(linuxCommand)
|
||||||
|
return
|
||||||
|
}
|
||||||
if linuxCommand == "a2prompt" {
|
if linuxCommand == "a2prompt" {
|
||||||
prompt := fmt.Sprintf("A2IO:%s ", workingDirectory)
|
prompt := fmt.Sprintf("A2IO:%s ", workingDirectory)
|
||||||
comm.WriteString(prompt)
|
comm.WriteString(prompt)
|
||||||
@ -100,14 +106,7 @@ func execCommand(linuxCommand string, workingDirectory string) {
|
|||||||
comm.WriteString("Failed to set stdout\r")
|
comm.WriteString("Failed to set stdout\r")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
stdin, err := cmd.StdinPipe()
|
|
||||||
if err != nil {
|
|
||||||
fmt.Printf("Failed to set stdin\n")
|
|
||||||
comm.WriteString("Failed to set stdin\r")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
fmt.Printf("Command output:\n")
|
|
||||||
err = cmd.Start()
|
err = cmd.Start()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf("Failed to start command\n")
|
fmt.Printf("Failed to start command\n")
|
||||||
@ -115,73 +114,26 @@ func execCommand(linuxCommand string, workingDirectory string) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
outputComplete := make(chan bool)
|
timeout := time.After(time.Duration(execTimeoutSeconds) * time.Second)
|
||||||
inputComplete := make(chan bool)
|
|
||||||
userCancelled := make(chan bool)
|
|
||||||
|
|
||||||
go getStdin(stdin, outputComplete, inputComplete, userCancelled)
|
|
||||||
go getStdout(stdout, outputComplete, userCancelled)
|
|
||||||
|
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case <-outputComplete:
|
case <-timeout:
|
||||||
outputComplete <- true
|
comm.WriteString("\rCancelled by apple2driver\r")
|
||||||
cmd.Wait()
|
|
||||||
comm.WriteByte(0)
|
|
||||||
return
|
|
||||||
case <-userCancelled:
|
|
||||||
userCancelled <- true
|
|
||||||
cmd.Process.Kill()
|
cmd.Process.Kill()
|
||||||
return
|
return
|
||||||
case <-inputComplete:
|
|
||||||
cmd.Wait()
|
|
||||||
comm.WriteByte(0)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func getStdout(stdout io.ReadCloser, outputComplete chan bool, userCancelled chan bool) {
|
|
||||||
for {
|
|
||||||
select {
|
|
||||||
case <-userCancelled:
|
|
||||||
fmt.Printf("User Cancelled stdout\n")
|
|
||||||
stdout.Close()
|
|
||||||
return
|
|
||||||
default:
|
default:
|
||||||
bb := make([]byte, 1)
|
bb := make([]byte, 1)
|
||||||
n, err := stdout.Read(bb)
|
n, stdOutErr := stdout.Read(bb)
|
||||||
if err != nil {
|
if stdOutErr == nil {
|
||||||
stdout.Close()
|
|
||||||
outputComplete <- true
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if n > 0 {
|
if n > 0 {
|
||||||
b := bb[0]
|
b := bb[0]
|
||||||
comm.SendCharacter(b)
|
comm.SendCharacter(b)
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
}
|
comm.WriteByte(0)
|
||||||
}
|
cmd.Wait()
|
||||||
|
|
||||||
func getStdin(stdin io.WriteCloser, done chan bool, inputComplete chan bool, userCancelled chan bool) {
|
|
||||||
for {
|
|
||||||
select {
|
|
||||||
case <-done:
|
|
||||||
stdin.Close()
|
|
||||||
inputComplete <- true
|
|
||||||
return
|
return
|
||||||
default:
|
|
||||||
b, err := comm.ReadByte()
|
|
||||||
if err == nil {
|
|
||||||
if b == 0x00 || b == 0x03 {
|
|
||||||
stdin.Close()
|
|
||||||
userCancelled <- true
|
|
||||||
fmt.Printf("\nUser cancelled stdin\n")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
bb := make([]byte, 1)
|
|
||||||
stdin.Write(bb)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -195,14 +147,34 @@ func a2help() {
|
|||||||
comm.WriteString("\r" +
|
comm.WriteString("\r" +
|
||||||
"Built-in commands:\r" +
|
"Built-in commands:\r" +
|
||||||
"------------------\r" +
|
"------------------\r" +
|
||||||
"a2version - display version number\r" +
|
|
||||||
"a2help - display this message\r" +
|
"a2help - display this message\r" +
|
||||||
|
"a2version - display version number\r" +
|
||||||
"a2wifi - set up wifi\r" +
|
"a2wifi - set up wifi\r" +
|
||||||
|
"a2timeout - seconds to timeout commands\r" +
|
||||||
"A2LOWER - force lowercase for II+\r" +
|
"A2LOWER - force lowercase for II+\r" +
|
||||||
"a2lower - disable force lowercase for II+\r" +
|
"a2lower - disable force lowercase for II+\r" +
|
||||||
"\r")
|
"\r")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func a2timeout(linuxCommand string) {
|
||||||
|
params := strings.Fields(linuxCommand)
|
||||||
|
|
||||||
|
switch len(params) {
|
||||||
|
case 1:
|
||||||
|
comm.WriteString("\rCommand timeout: " + strconv.FormatInt(int64(execTimeoutSeconds),10) + "\r")
|
||||||
|
case 2:
|
||||||
|
timeoutSeconds, err := strconv.ParseInt(params[1], 10, 32)
|
||||||
|
if err != nil {
|
||||||
|
comm.WriteString("\rFailed to parse timeout\r")
|
||||||
|
} else {
|
||||||
|
execTimeoutSeconds = int(timeoutSeconds)
|
||||||
|
comm.WriteString("\rCommand timeout set to: " + strconv.FormatInt(int64(execTimeoutSeconds),10) + "\r")
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
comm.WriteString("\rToo many parameters\n")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func a2lower(enable bool) {
|
func a2lower(enable bool) {
|
||||||
forceLowercase = enable
|
forceLowercase = enable
|
||||||
comm.WriteString(fmt.Sprintf("All commands will be converted to lowercase: %t\r", forceLowercase))
|
comm.WriteString(fmt.Sprintf("All commands will be converted to lowercase: %t\r", forceLowercase))
|
||||||
|
@ -8,4 +8,4 @@ package info
|
|||||||
|
|
||||||
// Version is the hexadecimal version number that
|
// Version is the hexadecimal version number that
|
||||||
// should be incremented with each driver update
|
// should be incremented with each driver update
|
||||||
const Version = "0024"
|
const Version = "0025"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user