From a74403c347e0c277e15a917d7e03aeaed8d8d3e0 Mon Sep 17 00:00:00 2001 From: Irmen de Jong Date: Thu, 26 Nov 2020 01:52:48 +0100 Subject: [PATCH] float typecasts optimization --- compiler/res/prog8lib/c64/floats.asm | 18 ++++++++++++++---- .../c64/codegen/assignment/AssignmentAsmGen.kt | 18 ++++++++++-------- 2 files changed, 24 insertions(+), 12 deletions(-) diff --git a/compiler/res/prog8lib/c64/floats.asm b/compiler/res/prog8lib/c64/floats.asm index bd05a1101..fa0baa503 100644 --- a/compiler/res/prog8lib/c64/floats.asm +++ b/compiler/res/prog8lib/c64/floats.asm @@ -89,17 +89,27 @@ cast_from_b .proc cast_as_uw_into_ya .proc ; also used for float 2 ub ; -- cast float at A/Y to uword into Y/A - stx P8ZP_SCRATCH_REG jsr MOVFM + jmp cast_FAC1_as_uw_into_ya + .pend + +cast_as_w_into_ay .proc ; also used for float 2 b + ; -- cast float at A/Y to word into A/Y + jsr MOVFM + jmp cast_FAC1_as_w_into_ay + .pend + +cast_FAC1_as_uw_into_ya .proc ; also used for float 2 ub + ; -- cast fac1 to uword into Y/A + stx P8ZP_SCRATCH_REG jsr GETADR ; into Y/A ldx P8ZP_SCRATCH_REG rts .pend -cast_as_w_into_ay .proc ; also used for float 2 b - ; -- cast float at A/Y to word into A/Y +cast_FAC1_as_w_into_ay .proc ; also used for float 2 b + ; -- cast fac1 to word into A/Y stx P8ZP_SCRATCH_REG - jsr MOVFM jsr AYINT ldy $64 lda $65 diff --git a/compiler/src/prog8/compiler/target/c64/codegen/assignment/AssignmentAsmGen.kt b/compiler/src/prog8/compiler/target/c64/codegen/assignment/AssignmentAsmGen.kt index 59a71f0c2..9edafe041 100644 --- a/compiler/src/prog8/compiler/target/c64/codegen/assignment/AssignmentAsmGen.kt +++ b/compiler/src/prog8/compiler/target/c64/codegen/assignment/AssignmentAsmGen.kt @@ -9,7 +9,6 @@ import prog8.compiler.target.CompilationTarget import prog8.compiler.target.CpuType import prog8.compiler.target.c64.codegen.AsmGen import prog8.compiler.target.c64.codegen.ExpressionsAsmGen -import prog8.compiler.target.subroutineFloatEvalResultVar import prog8.compiler.toHex import prog8.functions.BuiltinFunctions import prog8.functions.builtinFunctionReturnType @@ -282,13 +281,8 @@ internal class AssignmentAsmGen(private val program: Program, private val asmgen return assignTypeCastedRegisters(target.asmVarname, targetDt, RegisterOrPair.AY, valueDt) } DataType.FLOAT -> { - // TODO try with FAC1 directly -// assignExpressionToRegister(value, RegisterOrPair.FAC1) -// assignTypecastedFloatFAC1(target.asmVarname, targetDt) - val scope = value.definingSubroutine()!! - scope.asmGenInfo.usedFloatEvalResultVar = true - assignExpressionToVariable(value, subroutineFloatEvalResultVar, valueDt, scope) - return assignTypeCastedIdentifier(target.asmVarname, targetDt, subroutineFloatEvalResultVar, valueDt) + assignExpressionToRegister(value, RegisterOrPair.FAC1) + return assignTypecastedFloatFAC1(target.asmVarname, targetDt) } in PassByReferenceDatatypes -> { // str/array value cast (most likely to UWORD, take address-of) @@ -311,6 +305,14 @@ internal class AssignmentAsmGen(private val program: Program, private val asmgen if(targetDt==DataType.FLOAT) throw AssemblyError("typecast to identical type") + + when(targetDt) { + DataType.UBYTE -> asmgen.out(" jsr floats.cast_FAC1_as_uw_into_ya | sty $targetAsmVarName") + DataType.BYTE -> asmgen.out(" jsr floats.cast_FAC1_as_w_into_ay | sta $targetAsmVarName") + DataType.UWORD -> asmgen.out(" jsr floats.cast_FAC1_as_uw_into_ya | sty $targetAsmVarName | sta $targetAsmVarName+1") + DataType.WORD -> asmgen.out(" jsr floats.cast_FAC1_as_w_into_ay | sta $targetAsmVarName | sty $targetAsmVarName+1") + else -> throw AssemblyError("weird type") + } }