mirror of
https://github.com/dschmenk/PLASMA.git
synced 2025-04-05 03:37:43 +00:00
Cleanup
This commit is contained in:
parent
d0215eb7e1
commit
9e4f9936af
@ -24,9 +24,10 @@ const jitcomp = $03E2
|
||||
const jitcodeptr = $03E4
|
||||
const codemax = $BEE0
|
||||
//
|
||||
// AUX bytecode interpreter entrypoint
|
||||
// Bytecode interpreter entrypoints
|
||||
//
|
||||
const interpentry = $03DC
|
||||
const indirectentry = $03DC
|
||||
const directentry = $03D0
|
||||
//
|
||||
//
|
||||
//
|
||||
|
@ -27,13 +27,14 @@ end
|
||||
def compiler(defptr)#0
|
||||
word codeptr, isdata, addrxlate, bytecode, i, case, dest, VX, VY
|
||||
byte opcode, j, A_IS_TOSL
|
||||
|
||||
|
||||
//puts("JIT compiler invoked for :$"); puth(defptr=>bytecodeaddr); putln
|
||||
if isult(heapavail, 512 + defptr->bytecodesize) // 256 * sizeof(word) address xlate
|
||||
//
|
||||
// Not enough heap available
|
||||
//
|
||||
defptr=>interpaddr = interpentry
|
||||
//puts("Not enough free heap\n")
|
||||
defptr=>interpaddr = indirectentry
|
||||
return
|
||||
fin
|
||||
addrxlate = heapmark
|
||||
@ -166,7 +167,7 @@ def compiler(defptr)#0
|
||||
// Call into VM
|
||||
//
|
||||
codeptr->0 = $20 // JSR INTERP
|
||||
codeptr=>1 = $3D0
|
||||
codeptr=>1 = directentry
|
||||
codeptr->3 = $58 // ENTER CODE
|
||||
codeptr=>4 = *(bytecode+1) // ENTER FRAME SIZE & ARG COUNT
|
||||
codeptr->6 = $C0 // NATV CODE
|
||||
@ -428,7 +429,7 @@ def compiler(defptr)#0
|
||||
*codeptr = $D0B5+(VX<<8) // LDA ESTKL,X
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
codeptr->0 = $18 // CLC
|
||||
codeptr->0 = $18 // CLC
|
||||
codeptr=>1 = $69+(j<<8) // ADC #imm
|
||||
codeptr=>3 = $0290 // BCC +2
|
||||
codeptr=>5 = $C0F6+(VX<<8) // INC ESTKH,X
|
||||
@ -448,7 +449,7 @@ def compiler(defptr)#0
|
||||
*codeptr = $D0B5+(VX<<8) // LDA ESTKL,X
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
codeptr->0 = $38 // SEC
|
||||
codeptr->0 = $38 // SEC
|
||||
codeptr=>1 = $E9+(j<<8) // SBC #imm
|
||||
codeptr=>3 = $02B0 // BCS +2
|
||||
codeptr=>5 = $C0D6+(VX<<8) // DEC ESTKH,X
|
||||
@ -505,7 +506,7 @@ def compiler(defptr)#0
|
||||
codeptr=>0 = $D0D5+$0100+(VX<<8) // CMP ESTKL+1,X
|
||||
codeptr=>4 = $C0B5+(VX<<8) // LDA ESTKH,X
|
||||
codeptr=>6 = $C0D5+$0100+(VX<<8) // CMP ESTKH+1
|
||||
codeptr=>10 = $9888 // DEY; TYA
|
||||
codeptr=>10 = $9888 // DEY; TYA
|
||||
codeptr=>12 = $C094+$0100+(VX<<8) // STY ESTKH+1,X
|
||||
codeptr = codeptr + 14
|
||||
VX++ // INX
|
||||
@ -534,7 +535,7 @@ def compiler(defptr)#0
|
||||
//puts("ISLE")
|
||||
codeptr=>10 = $0130 // BMI +1
|
||||
fin
|
||||
codeptr=>12 = $9888 // DEY TYA
|
||||
codeptr=>12 = $9888 // DEY TYA
|
||||
codeptr=>14 = $C094+$0100+(VX<<8) // STY ESTKH+1,X
|
||||
codeptr = codeptr + 16
|
||||
VX++ // INX
|
||||
@ -564,7 +565,7 @@ def compiler(defptr)#0
|
||||
//puts("ISGE")
|
||||
codeptr=>12 = $0130 // BMI +1
|
||||
fin
|
||||
codeptr=>14 = $9888 // DEY; TYA
|
||||
codeptr=>14 = $9888 // DEY; TYA
|
||||
codeptr=>16 = $C094+$0100+(VX<<8) // STY ESTKH+1,X
|
||||
codeptr = codeptr + 18
|
||||
VX++ // INX
|
||||
@ -716,7 +717,7 @@ def compiler(defptr)#0
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
codeptr->0 = $20 // JSR abs
|
||||
codeptr=>1 = $03D0 // INTERP
|
||||
codeptr=>1 = directentry // INTERP
|
||||
codeptr=>3 = $5A + (^(bytecode+i)<<8) // LEAVE CODE AND OPERAND
|
||||
codeptr = codeptr + 5
|
||||
A_IS_TOSL = FALSE
|
||||
@ -877,7 +878,7 @@ def compiler(defptr)#0
|
||||
codeptr = codeptr + 2
|
||||
A_IS_TOSL = TOS_CLEAN
|
||||
fin
|
||||
if VY <> j
|
||||
if VY <> j
|
||||
*codeptr = $A0+(j<<8) // LDY #imm
|
||||
codeptr = codeptr + 2
|
||||
VY = j
|
||||
@ -900,7 +901,7 @@ def compiler(defptr)#0
|
||||
*codeptr = $D0B5+(VX<<8) // LDA ESTKL,X
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
if VY <> j
|
||||
if VY <> j
|
||||
*codeptr = $A0+(j<<8) // LDY #imm
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
@ -1066,7 +1067,7 @@ def compiler(defptr)#0
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
codeptr->0 = $20 // JSR INTERP
|
||||
codeptr=>1 = $3D0 // INTERP
|
||||
codeptr=>1 = directentry // INTERP
|
||||
codeptr=>3 = $C000+opcode // OPCODE; NATV CODE
|
||||
codeptr = codeptr + 5
|
||||
VY = UNKNOWN
|
||||
@ -1181,7 +1182,7 @@ def compiler(defptr)#0
|
||||
codeptr = codeptr + 19
|
||||
A_IS_TOSL = FALSE
|
||||
break
|
||||
is $A2 // BRLT - FOR/NEXT SPECIFIC TEST & BRANCH
|
||||
is $A2 // BRLT - FOR/NEXT SPECIFIC TEST & BRANCH
|
||||
i++
|
||||
dest = i + *(bytecode+i)
|
||||
//puts("BRLT "); puti(dest)
|
||||
@ -1361,11 +1362,11 @@ def compiler(defptr)#0
|
||||
*codeptr = $D0B5+(VX<<8) // LDA ESTKL,X
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
if VY <> j
|
||||
if VY <> j
|
||||
*codeptr = $A0+(j<<8) // LDY #imm
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
codeptr->0 = $18 // CLC
|
||||
codeptr->0 = $18 // CLC
|
||||
codeptr=>1 = $E071 // ADC (IFP),Y
|
||||
if opcode == $B0
|
||||
//puts("ADDLB "); puti(j)
|
||||
@ -1395,7 +1396,7 @@ def compiler(defptr)#0
|
||||
*codeptr = $D0B5+(VX<<8) // LDA ESTKL,X
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
codeptr=>0 = $6D18 // CLC; ADC abs
|
||||
codeptr=>0 = $6D18 // CLC; ADC abs
|
||||
codeptr=>2 = dest
|
||||
if opcode == $B4
|
||||
//puts("ADDAB $"); puth(dest)
|
||||
@ -1407,7 +1408,7 @@ def compiler(defptr)#0
|
||||
//puts("ADDAW $"); puth(dest)
|
||||
codeptr=>4 = $D095+(VX<<8) // STA ESTKL,X
|
||||
codeptr=>6 = $C0B5+(VX<<8) // LDA ESTKH,X
|
||||
codeptr->8 = $6D // ADC abs
|
||||
codeptr->8 = $6D // ADC abs
|
||||
codeptr=>9 = dest+1
|
||||
codeptr=>11 = $C095+(VX<<8) // STA ESTKH,X
|
||||
codeptr = codeptr + 13
|
||||
@ -1422,13 +1423,13 @@ def compiler(defptr)#0
|
||||
*codeptr = $D095+(VX<<8) // STA ESTKL,X
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
if VY <> j
|
||||
if VY <> j
|
||||
*codeptr = $A0+(j<<8) // LDY #imm
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
*codeptr = $E0B1 // LDA (IFP),Y
|
||||
codeptr = codeptr + 2
|
||||
if j
|
||||
if j
|
||||
*codeptr = $00A0 // LDY #$00
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
@ -1452,7 +1453,7 @@ def compiler(defptr)#0
|
||||
*codeptr = $D095+(VX<<8) // STA ESTKL,X
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
if VY <> j
|
||||
if VY <> j
|
||||
*codeptr = $A0+(j<<8) // LDY #imm
|
||||
codeptr = codeptr + 2
|
||||
fin
|
||||
@ -1512,7 +1513,7 @@ def compiler(defptr)#0
|
||||
codeptr=>1 = dest
|
||||
codeptr->3 = $0A // ASL
|
||||
codeptr=>4 = $E785 // STA $E7:TMPL
|
||||
codeptr->6 = $AD // LDA abs
|
||||
codeptr->6 = $AD // LDA abs
|
||||
codeptr=>7 = dest+1
|
||||
codeptr=>9 = $A82A // ROL; TAY
|
||||
codeptr=>11 = $E7A5 // LDA $E7:TMPL
|
||||
@ -1549,13 +1550,12 @@ def compiler(defptr)#0
|
||||
//getc
|
||||
return
|
||||
fin
|
||||
//if opcode == $B6; getc; fin
|
||||
loop
|
||||
//
|
||||
// If we got here. we ran out of code buffer space. Overwrite interpreter
|
||||
// entrypoint with standard bytecode interpreter
|
||||
//
|
||||
defptr=>interpaddr = interpentry
|
||||
defptr=>interpaddr = indirectentry
|
||||
//
|
||||
// Free working bufffers
|
||||
//
|
||||
|
@ -157,7 +157,7 @@ $(CMDJIT): vmsrc/apple/cmdjit.pla vmsrc/apple/cmdjitstub.s $(PLVMJIT) $(PLASM)
|
||||
./$(PLASM) -AOW < vmsrc/apple/cmdjit.pla > vmsrc/apple/cmdjit.a
|
||||
acme --setpc 8192 -o $(CMDJIT) vmsrc/apple/cmdjitstub.s
|
||||
|
||||
$(SOSCMD): vmsrc/apple/soscmd.pla $(PLVM03) $(PLASM)
|
||||
$(SOSCMD): vmsrc/apple/soscmd.pla libsrc/jitcore.pla $(PLVM03) $(PLASM)
|
||||
./$(PLASM) -AMOW < vmsrc/apple/soscmd.pla > vmsrc/apple/soscmd.a
|
||||
acme --setpc 4094 -o $(SOSCMD) vmsrc/apple/soscmd.a
|
||||
|
||||
@ -366,7 +366,7 @@ $(SOS): libsrc/apple/sos.pla $(PLVM03) $(PLASM)
|
||||
./$(PLASM) -AMO < libsrc/apple/sos.pla > libsrc/apple/sos.a
|
||||
acme --setpc 4094 -o $(SOS) libsrc/apple/sos.a
|
||||
|
||||
$(JIT): libsrc/apple/jit.pla $(PLVMJIT) $(PLASM)
|
||||
$(JIT): libsrc/apple/jit.pla libsrc/jitcore.pla $(PLVMJIT) $(PLASM)
|
||||
./$(PLASM) -AMO < libsrc/apple/jit.pla > libsrc/apple/jit.a
|
||||
acme --setpc 4094 -o $(JIT) libsrc/apple/jit.a
|
||||
|
||||
|
@ -16,13 +16,11 @@ end
|
||||
//
|
||||
// JIT compiler values
|
||||
//
|
||||
const jitcomp = $B7F0
|
||||
const jitcodeptr = $B7F2
|
||||
const codemax = $A000
|
||||
word interpentry
|
||||
//
|
||||
// AUX bytecode interpreter entrypoint
|
||||
//
|
||||
const jitcomp = $B7F0
|
||||
const jitcodeptr = $B7F2
|
||||
const codemax = $A000
|
||||
const directentry = $A0C2 // Right afer opcode table
|
||||
const indirectentry = $A0D5 // Yikes! Grabbed from plvm03.sym
|
||||
//
|
||||
// COPY FROM EXT MEM TO MAIN MEM.
|
||||
//
|
||||
@ -38,7 +36,7 @@ DSTX = XPAGE+DSTH
|
||||
ORA ESTKH,X
|
||||
BEQ CPYXMEX
|
||||
LDA ESTKL+3,X
|
||||
STY DSTL
|
||||
STA DSTL
|
||||
LDA ESTKH+3,X
|
||||
STA DSTH
|
||||
LDA ESTKL+2,X
|
||||
@ -47,6 +45,8 @@ DSTX = XPAGE+DSTH
|
||||
STA SRCH
|
||||
LDA ESTKL+1,X
|
||||
STA SRCX
|
||||
INC ESTKH,X
|
||||
LDY #$00
|
||||
CPYXLP LDA (SRC),Y
|
||||
STA (DST),Y
|
||||
INY
|
||||
@ -313,8 +313,7 @@ cmdsys:cmdparser = @shell
|
||||
//
|
||||
// Install JIT compiler
|
||||
//
|
||||
interpentry = compiler:interpaddr
|
||||
*jitcomp = @compiler
|
||||
cmdsys.jitcount = 44
|
||||
//cmdsys.jitsize = 96
|
||||
cmdsys.jitsize = 96
|
||||
done
|
||||
|
Loading…
x
Reference in New Issue
Block a user