Apple2-IO-RPi/Apple2/Shell.asm
Terence Boldt 5910d66fa2
Auto boot with recovery and improved VT100 support (#45)
* Improve vt100 support to make vim work

* Fix home and add line clear

* Auto boot with recovery
2021-11-25 18:45:56 -05:00

197 lines
2.8 KiB
NASM
Executable File

;ProDOS Zero Page
Command = $42 ;ProDOS Command
Unit = $43 ;ProDOS unit (SDDD0000)
BufferLo = $44
BufferHi = $45
BlockLo = $46
BlockHi = $47
; ProDOS Error Codes
IOError = $27
NoDevice = $28
WriteProtect = $2B
; hard code slot to 7 for now, will make it auto-detect later
SLOT = 7
InputByte = $c08e+SLOT*$10
OutputByte = $c08d+SLOT*$10
InputFlags = $c08b+SLOT*$10
OutputFlags = $c087+SLOT*$10
ReadBlockCommand = $01
WriteBlockCommand = $02
GetTimeCommand = $03
ChangeDriveCommand = $04
ExecCommand = $05
LoadFileCommand = $06
SaveFileCommand = $07
MenuCommand = $08
ShellCommand = $09
InputString = $fd6a
StringBuffer = $0200
PrintChar = $fded
Keyboard = $c000
ClearKeyboard = $c010
Home = $fc58
Wait = $fca8
PromptChar = $33
Read80Col = $c01f
TextPage1 = $c054
TextPage2 = $c055
htab = $24
vtab = $25
BasL = $28
htab80 = $057b
BasCalc = $fbc1
ESC = $9b
.org $2000
Start:
jsr $c300 ; force 80 columns
bit ClearKeyboard
lda #ShellCommand
jsr SendByte
jsr DumpOutput
rts
DumpOutput:
jsr GetByte
bcs checkInput
cmp #$00
beq endOutput
pha
jsr InvertChar
pla
cmp #'H'
beq setColumn
cmp #'V'
beq setRow
cmp #'C'
beq clearScreen
cmp #'T'
beq setTop
cmp #'B'
beq setBottom
cmp #'U'
beq moveUp
jsr PrintChar
jsr InvertChar
jmp DumpOutput
checkInput:
bit Keyboard ;check for keypress
bpl DumpOutput ;keep dumping output if no keypress
lda Keyboard ;send keypress to RPi
and #$7f
jsr SendByte
bit ClearKeyboard
jmp DumpOutput
endOutput:
rts
clearScreen:
jsr Home
jsr InvertChar
jmp DumpOutput
setColumn:
jsr GetByte
sta htab
sta htab80
jsr InvertChar
jmp DumpOutput
setRow:
jsr GetByte
sta vtab
jsr BasCalc
jsr InvertChar
jmp DumpOutput
setTop:
jsr GetByte
sta $22
jsr InvertChar
jmp DumpOutput
setBottom:
jsr GetByte
sta $23
jsr InvertChar
jmp DumpOutput
moveUp:
dec vtab
lda vtab
jsr BasCalc
jsr InvertChar
jmp DumpOutput
SendByte:
pha
waitWrite:
lda InputFlags
rol
rol
bcs waitWrite
pla
sta OutputByte
lda #$1e ; set bit 0 low to indicate write started
sta OutputFlags
finishWrite:
lda InputFlags
rol
rol
bcc finishWrite
lda #$1f
sta OutputFlags
rts
GetByte:
lda #$1d ;set read flag low
sta OutputFlags
waitRead:
lda InputFlags
rol
bcc readByte
bit Keyboard ;keypress will abort waiting to read
bpl waitRead
lda #$1f ;set all flags high and exit
sta OutputFlags
sec ;failure
rts
readByte:
lda InputByte
pha
lda #$1f ;set all flags high
sta OutputFlags
finishRead:
lda InputFlags
rol
bcc finishRead
pla
clc ;success
end:
rts
InvertChar:
lda htab80 ;get horizontal location / 2
lsr
tay
lda TextPage2
bcc invert
lda TextPage1
invert:
lda (BasL),y
eor #$80
sta (BasL),y
lda TextPage1
screen40:
rts
HelpCommand:
.byte "a2help",$00
PromptCommand:
.byte "a2prompt",$00
OldPromptChar:
.byte "]"
DrawCursor:
.byte $80