mirror of
https://github.com/irmen/prog8.git
synced 2025-01-12 04:30:03 +00:00
adding setlsb() and setmsb() builtin functions to 6502 codegen
This commit is contained in:
parent
95e4490a8a
commit
a1874f6f00
@ -612,7 +612,51 @@ internal class BuiltinFunctionsAsmGen(private val program: PtProgram,
|
|||||||
}
|
}
|
||||||
|
|
||||||
private fun funcSetLsbMsb(fcall: PtBuiltinFunctionCall, msb: Boolean) {
|
private fun funcSetLsbMsb(fcall: PtBuiltinFunctionCall, msb: Boolean) {
|
||||||
TODO("setlsb/setmsb for $fcall")
|
asmgen.assignExpressionToRegister(fcall.args[1], RegisterOrPair.A, false)
|
||||||
|
|
||||||
|
val address: PtExpression
|
||||||
|
when(fcall.args[0]) {
|
||||||
|
is PtIdentifier -> {
|
||||||
|
if(msb) {
|
||||||
|
address = PtBinaryExpression("+", DataType.UWORD, fcall.args[0].position)
|
||||||
|
val addressOf = PtAddressOf(fcall.position)
|
||||||
|
addressOf.add(fcall.args[0])
|
||||||
|
address.add(addressOf)
|
||||||
|
address.add(PtNumber(address.type, 1.0, fcall.args[0].position))
|
||||||
|
} else {
|
||||||
|
address = PtAddressOf(fcall.position)
|
||||||
|
address.add(fcall.args[0])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
is PtNumber -> {
|
||||||
|
val num = (fcall.args[0] as PtNumber).number + if(msb) 1 else 0
|
||||||
|
address = PtNumber(fcall.args[0].type, num, fcall.args[0].position)
|
||||||
|
}
|
||||||
|
is PtAddressOf -> {
|
||||||
|
if(msb) {
|
||||||
|
address = PtBinaryExpression("+", DataType.UWORD, fcall.args[0].position)
|
||||||
|
address.add(fcall.args[0])
|
||||||
|
address.add(PtNumber(address.type, 1.0, fcall.args[0].position))
|
||||||
|
} else {
|
||||||
|
address = fcall.args[0]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
is PtArrayIndexer -> {
|
||||||
|
val indexer = fcall.args[0] as PtArrayIndexer
|
||||||
|
require(!indexer.usesPointerVariable)
|
||||||
|
if(indexer.splitWords) {
|
||||||
|
// lsb/msb in split arrays, element index 'size' is always 1
|
||||||
|
TODO("setlsb/setmsb on split array element ${fcall.position}")
|
||||||
|
} else {
|
||||||
|
TODO("setlsb/setmsb on array element ${fcall.position}")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else -> throw AssemblyError("setlsb/setmsb on weird target ${fcall.args[0]}")
|
||||||
|
}
|
||||||
|
val mem = PtMemoryByte(fcall.position)
|
||||||
|
mem.add(address)
|
||||||
|
mem.parent = fcall
|
||||||
|
assignAsmGen.storeRegisterAInMemoryAddress(mem) // TODO use assignRegisterByte()???, and assignConstantByte() if the value is contstant zero
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun funcSgn(fcall: PtBuiltinFunctionCall, resultRegister: RegisterOrPair?, scope: IPtSubroutine?) {
|
private fun funcSgn(fcall: PtBuiltinFunctionCall, resultRegister: RegisterOrPair?, scope: IPtSubroutine?) {
|
||||||
|
@ -3589,7 +3589,7 @@ internal class AssignmentAsmGen(private val program: PtProgram,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun storeRegisterAInMemoryAddress(memoryAddress: PtMemoryByte) {
|
internal fun storeRegisterAInMemoryAddress(memoryAddress: PtMemoryByte) {
|
||||||
val addressExpr = memoryAddress.address
|
val addressExpr = memoryAddress.address
|
||||||
val addressLv = addressExpr as? PtNumber
|
val addressLv = addressExpr as? PtNumber
|
||||||
val addressOf = addressExpr as? PtAddressOf
|
val addressOf = addressExpr as? PtAddressOf
|
||||||
|
@ -597,6 +597,7 @@ internal class BuiltinFuncGen(private val codeGen: IRCodeGen, private val exprGe
|
|||||||
is PtArrayIndexer -> {
|
is PtArrayIndexer -> {
|
||||||
require(!target.usesPointerVariable)
|
require(!target.usesPointerVariable)
|
||||||
if(target.splitWords) {
|
if(target.splitWords) {
|
||||||
|
// lsb/msb in split arrays, element index 'size' is always 1
|
||||||
val varName = target.variable.name + if(msb) "_msb" else "_lsb"
|
val varName = target.variable.name + if(msb) "_msb" else "_lsb"
|
||||||
val valueTr = exprGen.translateExpression(call.args[1])
|
val valueTr = exprGen.translateExpression(call.args[1])
|
||||||
addToResult(result, valueTr, valueTr.resultReg, -1)
|
addToResult(result, valueTr, valueTr.resultReg, -1)
|
||||||
|
@ -7,9 +7,11 @@ main {
|
|||||||
txt.print_uwhex(zz, true)
|
txt.print_uwhex(zz, true)
|
||||||
txt.nl()
|
txt.nl()
|
||||||
|
|
||||||
|
;@(&zz) = $11
|
||||||
setlsb(zz, $11)
|
setlsb(zz, $11)
|
||||||
txt.print_uwhex(zz, true)
|
txt.print_uwhex(zz, true)
|
||||||
txt.nl()
|
txt.nl()
|
||||||
|
;@(&zz+1) = $22
|
||||||
setmsb(zz, $22)
|
setmsb(zz, $22)
|
||||||
txt.print_uwhex(zz, true)
|
txt.print_uwhex(zz, true)
|
||||||
txt.nl()
|
txt.nl()
|
||||||
@ -23,6 +25,8 @@ main {
|
|||||||
txt.nl()
|
txt.nl()
|
||||||
txt.print_uwhex(array[2], true)
|
txt.print_uwhex(array[2], true)
|
||||||
txt.nl()
|
txt.nl()
|
||||||
|
;@(&array+one*2) = $ff
|
||||||
|
;@(&array+two*2+1) = $ff
|
||||||
setlsb(array[one],$ff)
|
setlsb(array[one],$ff)
|
||||||
setmsb(array[two],$00)
|
setmsb(array[two],$00)
|
||||||
txt.print_uwhex(array[1], true)
|
txt.print_uwhex(array[1], true)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user