more bitshift asm

This commit is contained in:
Irmen de Jong 2019-08-23 21:32:21 +02:00
parent aa94300bdd
commit 1d178080a3
5 changed files with 93 additions and 39 deletions

View File

@ -1671,3 +1671,38 @@ _loop_hi sty c64.SCRATCH_ZPREG
rts rts
.pend .pend
ror2_mem_b .proc
; -- in-place 8-bit ror of byte at memory location on stack
inx
lda c64.ESTACK_LO,x
sta _mod1+1
sta _mod2+1
lda c64.ESTACK_HI,x
sta _mod1+2
sta _mod2+2
_mod1 lda $ffff ; modified
lsr a
bcc _mod2
ora #$80
_mod2 sta $ffff ; modified
rts
.pend
rol2_mem_b .proc
; -- in-place 8-bit rol of byte at memory location on stack
;" lda ${number.toHex()} | cmp #\$80 | rol a | sta ${number.toHex()}"
inx
lda c64.ESTACK_LO,x
sta _mod1+1
sta _mod2+1
lda c64.ESTACK_HI,x
sta _mod1+2
sta _mod2+2
_mod1 lda $ffff ; modified
cmp #$80
rol a
_mod2 sta $ffff ; modified
rts
.pend

View File

@ -97,7 +97,7 @@ fun compileProgram(filepath: Path,
programAst.checkValid(compilerOptions) // check if final tree is valid programAst.checkValid(compilerOptions) // check if final tree is valid
programAst.checkRecursion() // check if there are recursive subroutine calls programAst.checkRecursion() // check if there are recursive subroutine calls
// printAst(programAst) printAst(programAst)
if(writeAssembly) { if(writeAssembly) {
// asm generation directly from the Ast, no need for intermediate code // asm generation directly from the Ast, no need for intermediate code

View File

@ -44,7 +44,6 @@ class AssemblyProgram(val name: String, val outputDir: Path) {
} }
} }
command.addAll(listOf("--output", outFile.toString(), assemblyFile.toString())) command.addAll(listOf("--output", outFile.toString(), assemblyFile.toString()))
println("ASM COMMAND: $command") // TODO
val proc = ProcessBuilder(command).inheritIO().start() val proc = ProcessBuilder(command).inheritIO().start()
val result = proc.waitFor() val result = proc.waitFor()

View File

@ -121,24 +121,6 @@ internal class BuiltinFunctionsAsmGen(private val program: Program, private val
translateFunctionArguments(fcall.arglist, func) translateFunctionArguments(fcall.arglist, func)
asmgen.out(" jsr c64flt.func_$functionName") asmgen.out(" jsr c64flt.func_$functionName")
} }
/*
TODO this was the old code for bit rotations:
Opcode.SHL_BYTE -> AsmFragment(" asl $variable+$index", 8)
Opcode.SHR_UBYTE -> AsmFragment(" lsr $variable+$index", 8)
Opcode.SHR_SBYTE -> AsmFragment(" lda $variable+$index | asl a | ror $variable+$index")
Opcode.SHL_WORD -> AsmFragment(" asl $variable+${index * 2 + 1} | rol $variable+${index * 2}", 8)
Opcode.SHR_UWORD -> AsmFragment(" lsr $variable+${index * 2 + 1} | ror $variable+${index * 2}", 8)
Opcode.SHR_SWORD -> AsmFragment(" lda $variable+${index * 2 + 1} | asl a | ror $variable+${index * 2 + 1} | ror $variable+${index * 2}", 8)
Opcode.ROL_BYTE -> AsmFragment(" rol $variable+$index", 8)
Opcode.ROR_BYTE -> AsmFragment(" ror $variable+$index", 8)
Opcode.ROL_WORD -> AsmFragment(" rol $variable+${index * 2 + 1} | rol $variable+${index * 2}", 8)
Opcode.ROR_WORD -> AsmFragment(" ror $variable+${index * 2 + 1} | ror $variable+${index * 2}", 8)
Opcode.ROL2_BYTE -> AsmFragment(" lda $variable+$index | cmp #\$80 | rol $variable+$index", 8)
Opcode.ROR2_BYTE -> AsmFragment(" lda $variable+$index | lsr a | bcc + | ora #\$80 |+ | sta $variable+$index", 10)
Opcode.ROL2_WORD -> AsmFragment(" asl $variable+${index * 2 + 1} | rol $variable+${index * 2} | bcc + | inc $variable+${index * 2 + 1} |+", 20)
Opcode.ROR2_WORD -> AsmFragment(" lsr $variable+${index * 2 + 1} | ror $variable+${index * 2} | bcc + | lda $variable+${index * 2 + 1} | ora #\$80 | sta $variable+${index * 2 + 1} |+", 30)
*/
"lsl" -> { "lsl" -> {
// in-place // in-place
val what = fcall.arglist.single() val what = fcall.arglist.single()
@ -159,12 +141,18 @@ internal class BuiltinFunctionsAsmGen(private val program: Program, private val
val number = (what.addressExpression as NumericLiteralValue).number val number = (what.addressExpression as NumericLiteralValue).number
asmgen.out(" asl ${number.toHex()}") asmgen.out(" asl ${number.toHex()}")
} else { } else {
TODO("lsl memory byte $what") asmgen.translateExpression(what.addressExpression)
asmgen.out("""
inx
lda $ESTACK_LO_HEX,x
sta (+) + 1
lda $ESTACK_HI_HEX,x
sta (+) + 2
+ asl 0 ; modified
""")
} }
} }
is ArrayIndexedExpression -> { is ArrayIndexedExpression -> TODO("lsl byte array $what")
TODO("lsl byte array $what")
}
else -> throw AssemblyError("weird type") else -> throw AssemblyError("weird type")
} }
} }
@ -201,12 +189,18 @@ internal class BuiltinFunctionsAsmGen(private val program: Program, private val
val number = (what.addressExpression as NumericLiteralValue).number val number = (what.addressExpression as NumericLiteralValue).number
asmgen.out(" lsr ${number.toHex()}") asmgen.out(" lsr ${number.toHex()}")
} else { } else {
TODO("lsr memory byte $what") asmgen.translateExpression(what.addressExpression)
asmgen.out("""
inx
lda $ESTACK_LO_HEX,x
sta (+) + 1
lda $ESTACK_HI_HEX,x
sta (+) + 2
+ lsr 0 ; modified
""")
} }
} }
is ArrayIndexedExpression -> { is ArrayIndexedExpression -> TODO("lsr byte array $what")
TODO("lsr byte array $what")
}
else -> throw AssemblyError("weird type") else -> throw AssemblyError("weird type")
} }
} }
@ -256,7 +250,15 @@ internal class BuiltinFunctionsAsmGen(private val program: Program, private val
val number = (what.addressExpression as NumericLiteralValue).number val number = (what.addressExpression as NumericLiteralValue).number
asmgen.out(" rol ${number.toHex()}") asmgen.out(" rol ${number.toHex()}")
} else { } else {
TODO("rol memory byte $what") asmgen.translateExpression(what.addressExpression)
asmgen.out("""
inx
lda $ESTACK_LO_HEX,x
sta (+) + 1
lda $ESTACK_HI_HEX,x
sta (+) + 2
+ rol 0 ; modified
""")
} }
} }
is RegisterExpr -> { is RegisterExpr -> {
@ -299,7 +301,8 @@ internal class BuiltinFunctionsAsmGen(private val program: Program, private val
val number = (what.addressExpression as NumericLiteralValue).number val number = (what.addressExpression as NumericLiteralValue).number
asmgen.out(" lda ${number.toHex()} | cmp #\$80 | rol a | sta ${number.toHex()}") asmgen.out(" lda ${number.toHex()} | cmp #\$80 | rol a | sta ${number.toHex()}")
} else { } else {
TODO("rol2 memory byte $what") asmgen.translateExpression(what.addressExpression)
asmgen.out(" jsr prog8_lib.rol2_mem_b")
} }
} }
is RegisterExpr -> { is RegisterExpr -> {
@ -342,8 +345,15 @@ internal class BuiltinFunctionsAsmGen(private val program: Program, private val
val number = (what.addressExpression as NumericLiteralValue).number val number = (what.addressExpression as NumericLiteralValue).number
asmgen.out(" ror ${number.toHex()}") asmgen.out(" ror ${number.toHex()}")
} else { } else {
TODO("ror memory byte $what") asmgen.translateExpression(what.addressExpression)
} asmgen.out("""
inx
lda $ESTACK_LO_HEX,x
sta (+) + 1
lda $ESTACK_HI_HEX,x
sta (+) + 2
+ ror 0 ; modified
""") }
} }
is RegisterExpr -> { is RegisterExpr -> {
when(what.register) { when(what.register) {
@ -385,7 +395,8 @@ internal class BuiltinFunctionsAsmGen(private val program: Program, private val
val number = (what.addressExpression as NumericLiteralValue).number val number = (what.addressExpression as NumericLiteralValue).number
asmgen.out(" lda ${number.toHex()} | lsr a | bcc + | ora #\$80 |+ | sta ${number.toHex()}") asmgen.out(" lda ${number.toHex()} | lsr a | bcc + | ora #\$80 |+ | sta ${number.toHex()}")
} else { } else {
TODO("ror2 memory byte $what") asmgen.translateExpression(what.addressExpression)
asmgen.out(" jsr prog8_lib.ror2_mem_b")
} }
} }
is RegisterExpr -> { is RegisterExpr -> {

View File

@ -15,12 +15,12 @@ main {
byte[10] bbarray byte[10] bbarray
sub start() { sub start() {
lsr(A) ; lsr(A)
lsl(A) ; lsl(A)
ror(A) ; ror(A)
rol(A) ; rol(A)
ror2(A) ; ror2(A)
rol2(A) ; rol2(A)
lsr(bb) lsr(bb)
lsl(bb) lsl(bb)
@ -37,12 +37,21 @@ main {
rol(memword) rol(memword)
ror2(memword) ror2(memword)
rol2(memword) rol2(memword)
lsl(@(9999)) lsl(@(9999))
lsr(@(9999)) lsr(@(9999))
ror(@(9999)) ror(@(9999))
rol(@(9999)) rol(@(9999))
ror2(@(9999)) ror2(@(9999))
rol2(@(9999)) rol2(@(9999))
lsl(@(9999+A))
lsr(@(9999+A))
ror(@(9999+A))
rol(@(9999+A))
ror2(@(9999+A))
rol2(@(9999+A))
lsr(ubarray[1]) lsr(ubarray[1])
lsl(ubarray[1]) lsl(ubarray[1])
ror(ubarray[1]) ror(ubarray[1])