From 75514fc7af661183b029425188f067a40ef9cd9c Mon Sep 17 00:00:00 2001 From: Irmen de Jong Date: Mon, 14 Aug 2023 21:58:26 +0200 Subject: [PATCH] fix some invalid instructions on 6502 (instead of 65c02) target for bit shifts --- .../src/prog8/codegen/cpu6502/assignment/AssignmentAsmGen.kt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/codeGenCpu6502/src/prog8/codegen/cpu6502/assignment/AssignmentAsmGen.kt b/codeGenCpu6502/src/prog8/codegen/cpu6502/assignment/AssignmentAsmGen.kt index 6c339da06..31463cde4 100644 --- a/codeGenCpu6502/src/prog8/codegen/cpu6502/assignment/AssignmentAsmGen.kt +++ b/codeGenCpu6502/src/prog8/codegen/cpu6502/assignment/AssignmentAsmGen.kt @@ -602,7 +602,7 @@ internal class AssignmentAsmGen(private val program: PtProgram, asmgen.out(" pha") if(dt in ByteDatatypes) { assignExpressionToRegister(expr.left, RegisterOrPair.A, signed) - asmgen.out(" ply") + asmgen.restoreRegisterStack(CpuRegister.Y, true) if(expr.operator==">>") if(signed) asmgen.out(" jsr math.lsr_byte_A") @@ -614,7 +614,7 @@ internal class AssignmentAsmGen(private val program: PtProgram, return true } else { assignExpressionToRegister(expr.left, RegisterOrPair.AY, signed) - asmgen.out(" plx") + asmgen.restoreRegisterStack(CpuRegister.X, true) if(expr.operator==">>") if(signed) asmgen.out(" jsr math.lsr_word_AY")