mirror of
https://github.com/irmen/prog8.git
synced 2025-01-11 13:29:45 +00:00
fix non-existing instructions txy/tyx, oops
This commit is contained in:
parent
e35cfd4971
commit
5d88717f32
@ -381,15 +381,9 @@ private fun optimizeStoreLoadSame(
|
|||||||
} else if(first=="phx" && second=="pla") {
|
} else if(first=="phx" && second=="pla") {
|
||||||
mods.add(Modification(lines[1].index, true, null))
|
mods.add(Modification(lines[1].index, true, null))
|
||||||
mods.add(Modification(lines[2].index, false, " txa"))
|
mods.add(Modification(lines[2].index, false, " txa"))
|
||||||
} else if(first=="phx" && second=="ply") {
|
|
||||||
mods.add(Modification(lines[1].index, true, null))
|
|
||||||
mods.add(Modification(lines[2].index, false, " txy"))
|
|
||||||
} else if(first=="phy" && second=="pla") {
|
} else if(first=="phy" && second=="pla") {
|
||||||
mods.add(Modification(lines[1].index, true, null))
|
mods.add(Modification(lines[1].index, true, null))
|
||||||
mods.add(Modification(lines[2].index, false, " tya"))
|
mods.add(Modification(lines[2].index, false, " tya"))
|
||||||
} else if(first=="phy" && second=="plx") {
|
|
||||||
mods.add(Modification(lines[1].index, true, null))
|
|
||||||
mods.add(Modification(lines[2].index, false, " tyx"))
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return mods
|
return mods
|
||||||
|
@ -3040,7 +3040,7 @@ internal class AssignmentAsmGen(private val program: PtProgram,
|
|||||||
CpuRegister.X -> when(target.register!!) {
|
CpuRegister.X -> when(target.register!!) {
|
||||||
RegisterOrPair.A -> { asmgen.out(" txa") }
|
RegisterOrPair.A -> { asmgen.out(" txa") }
|
||||||
RegisterOrPair.X -> { }
|
RegisterOrPair.X -> { }
|
||||||
RegisterOrPair.Y -> { asmgen.out(" txy") }
|
RegisterOrPair.Y -> { asmgen.out(" stx P8ZP_SCRATCH_REG | ldy P8ZP_SCRATCH_REG") }
|
||||||
RegisterOrPair.AY -> {
|
RegisterOrPair.AY -> {
|
||||||
require(extendWord)
|
require(extendWord)
|
||||||
if(signed)
|
if(signed)
|
||||||
@ -3090,7 +3090,7 @@ internal class AssignmentAsmGen(private val program: PtProgram,
|
|||||||
}
|
}
|
||||||
CpuRegister.Y -> when(target.register!!) {
|
CpuRegister.Y -> when(target.register!!) {
|
||||||
RegisterOrPair.A -> { asmgen.out(" tya") }
|
RegisterOrPair.A -> { asmgen.out(" tya") }
|
||||||
RegisterOrPair.X -> { asmgen.out(" tyx") }
|
RegisterOrPair.X -> { asmgen.out(" sty P8ZP_SCRATCH_REG | ldx P8ZP_SCRATCH_REG") }
|
||||||
RegisterOrPair.Y -> { }
|
RegisterOrPair.Y -> { }
|
||||||
RegisterOrPair.AY -> {
|
RegisterOrPair.AY -> {
|
||||||
require(extendWord)
|
require(extendWord)
|
||||||
|
@ -2,7 +2,6 @@
|
|||||||
TODO
|
TODO
|
||||||
====
|
====
|
||||||
|
|
||||||
- fix "txy" and "tyx" non-existing instructions (assembler/experiment/* causes them to be used)
|
|
||||||
- fix a1%a2 being parsed as directive
|
- fix a1%a2 being parsed as directive
|
||||||
- fix bitshift.p8
|
- fix bitshift.p8
|
||||||
- add crc8 and crc16 and crc32 to math
|
- add crc8 and crc16 and crc32 to math
|
||||||
|
Loading…
x
Reference in New Issue
Block a user