From 09f25ffbd999e3e7da5ee321f193d5205ecaed69 Mon Sep 17 00:00:00 2001 From: Irmen de Jong Date: Tue, 24 Nov 2020 21:41:44 +0100 Subject: [PATCH] optimized in-place memory var modification, not using translateExpression() --- .../assignment/AugmentableAssignmentAsmGen.kt | 39 +++++---------- examples/test.p8 | 48 +++++++------------ 2 files changed, 31 insertions(+), 56 deletions(-) diff --git a/compiler/src/prog8/compiler/target/c64/codegen/assignment/AugmentableAssignmentAsmGen.kt b/compiler/src/prog8/compiler/target/c64/codegen/assignment/AugmentableAssignmentAsmGen.kt index 528cff458..5e0fc02aa 100644 --- a/compiler/src/prog8/compiler/target/c64/codegen/assignment/AugmentableAssignmentAsmGen.kt +++ b/compiler/src/prog8/compiler/target/c64/codegen/assignment/AugmentableAssignmentAsmGen.kt @@ -228,26 +228,19 @@ internal class AugmentableAssignmentAsmGen(private val program: Program, } private fun inplaceModification_byte_value_to_pointer(pointervar: IdentifierReference, operator: String, value: Expression) { - if(asmgen.options.slowCodegenWarnings) - println("warning: slow stack evaluation used (3): @(${pointervar.nameInSource.last()}) $operator= ${value::class.simpleName} at ${value.position}") // TODO - asmgen.translateExpression(value) + asmgen.assignExpressionToVariable(value, "P8ZP_SCRATCH_B1", DataType.UBYTE, null) val (ptrOnZp, sourceName) = asmgen.loadByteFromPointerIntoA(pointervar) when (operator) { // note: ** (power) operator requires floats. - "+" -> asmgen.out(" clc | adc P8ESTACK_LO+1,x") - "-" -> asmgen.out(" sec | sbc P8ESTACK_LO+1,x") - "*" -> asmgen.out(" pha | lda P8ESTACK_LO+1,x | tay | pla | jsr math.multiply_bytes | ldy #0") - "/" -> asmgen.out(" pha | lda P8ESTACK_LO+1,x | tay | pla | jsr math.divmod_ub_asm | tya | ldy #0") - "%" -> asmgen.out(" pha | lda P8ESTACK_LO+1,x | tay | pla | jsr math.divmod_ub_asm | ldy #0") + "+" -> asmgen.out(" clc | adc P8ZP_SCRATCH_B1") + "-" -> asmgen.out(" sec | sbc P8ZP_SCRATCH_B1") + "*" -> asmgen.out(" ldy P8ZP_SCRATCH_B1 | jsr math.multiply_bytes | ldy #0") + "/" -> asmgen.out(" ldy P8ZP_SCRATCH_B1 | jsr math.divmod_ub_asm | tya | ldy #0") + "%" -> asmgen.out(" ldy P8ZP_SCRATCH_B1 | jsr math.divmod_ub_asm | ldy #0") "<<" -> { asmgen.out(""" - pha - lda P8ESTACK_LO+1,x - bne + - pla - rts -+ tay - pla + ldy P8ZP_SCRATCH_B1 + beq + - asl a dey bne - @@ -255,28 +248,22 @@ internal class AugmentableAssignmentAsmGen(private val program: Program, } ">>" -> { asmgen.out(""" - pha - lda P8ESTACK_LO+1,x - bne + - pla - rts -+ tay - pla + ldy P8ZP_SCRATCH_B1 + beq + - lsr a dey bne - +""") } - "&" -> asmgen.out(" and P8ESTACK_LO+1,x") - "^" -> asmgen.out(" eor P8ESTACK_LO+1,x") - "|" -> asmgen.out(" ora P8ESTACK_LO+1,x") + "&" -> asmgen.out(" and P8ZP_SCRATCH_B1") + "^" -> asmgen.out(" eor P8ZP_SCRATCH_B1") + "|" -> asmgen.out(" ora P8ZP_SCRATCH_B1") else -> throw AssemblyError("invalid operator for in-place modification $operator") } if(ptrOnZp) asmgen.out(" sta ($sourceName),y") else asmgen.out(" sta (P8ZP_SCRATCH_W1),y") - asmgen.out(" inx") } private fun inplaceModification_byte_variable_to_pointer(pointervar: IdentifierReference, operator: String, value: IdentifierReference) { diff --git a/examples/test.p8 b/examples/test.p8 index 4d6e2087b..95f549d6b 100644 --- a/examples/test.p8 +++ b/examples/test.p8 @@ -7,43 +7,31 @@ main { sub start() { - float fl = 2.0 - float cf = 1.5 + uword address = $c000 + ubyte ub = 1 + ubyte ub2 = 1 - if fl == cf+0.5 - txt.print(".\n") - else - txt.print("!\n") + @(address) = 13 - if fl != cf+0.5 - txt.print("!\n") - else - txt.print(".\n") + @(address) <<= ub+ub2 - if fl < cf+0.5 - txt.print("!\n") - else - txt.print(".\n") + txt.print_ub(@(address)) + txt.chrout('\n') + txt.print_ub(13 << (ub+ub2)) + txt.chrout('\n') - if fl <= cf+0.5 - txt.print(".\n") - else - txt.print("!\n") - if fl > cf+0.5 - txt.print("!\n") - else - txt.print(".\n") + @(address) = 200 - if fl >= cf+0.5 - txt.print(".\n") - else - txt.print("!\n") + @(address) >>= ub+ub2 - } + txt.print_ub(@(address)) + txt.chrout('\n') + txt.print_ub(200 >> (ub+ub2)) + txt.chrout('\n') + + + test_stack.test() - sub func(float fa) -> float { - fa = fa*99.0 - return fa + 1.0 } }