mirror of
https://github.com/KarolS/millfork.git
synced 2025-01-25 14:30:08 +00:00
65816: Various codegen bugfixes
This commit is contained in:
parent
c9f602b049
commit
1decf2f087
@ -31,6 +31,12 @@ object SixteenOptimizations {
|
|||||||
(Elidable & HasOpcode(XBA) & DoesntMatterWhatItDoesWith(State.A, State.AH, State.N, State.Z)) ~~> { code =>
|
(Elidable & HasOpcode(XBA) & DoesntMatterWhatItDoesWith(State.A, State.AH, State.N, State.Z)) ~~> { code =>
|
||||||
Nil
|
Nil
|
||||||
},
|
},
|
||||||
|
(Elidable & HasOpcode(XBA) & DoesntMatterWhatItDoesWith(State.N, State.Z) & HasAccu8 & HasIndex8) ~
|
||||||
|
(Elidable & HasOpcode(TAX)) ~
|
||||||
|
(Elidable & HasOpcode(XBA)) ~
|
||||||
|
(Elidable & HasOpcode(TXA) & DoesntMatterWhatItDoesWith(State.X, State.AH)) ~~> { code =>
|
||||||
|
List(code.head)
|
||||||
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
val RepSepWeakening = new RuleBasedAssemblyOptimization("REP/SEP weakening",
|
val RepSepWeakening = new RuleBasedAssemblyOptimization("REP/SEP weakening",
|
||||||
|
@ -788,7 +788,7 @@ object MosExpressionCompiler extends AbstractExpressionCompiler[AssemblyLine] {
|
|||||||
if (exprType.size > target.typ.size) {
|
if (exprType.size > target.typ.size) {
|
||||||
ctx.log.error(s"Variable `$target.name` is too small", expr.position)
|
ctx.log.error(s"Variable `$target.name` is too small", expr.position)
|
||||||
Nil
|
Nil
|
||||||
} else if (exprType.size == 2 && target.typ.size == 2 && ctx.options.flag(CompilationFlag.EmitNative65816Opcodes)) {
|
} else if (exprType.size == 2 && AbstractExpressionCompiler.getExpressionType(ctx, expr).size == 2 && target.typ.size == 2 && ctx.options.flag(CompilationFlag.EmitNative65816Opcodes)) {
|
||||||
AssemblyLine.accu16 :: (AssemblyLine.variable(ctx, LDA_W, source) ++ AssemblyLine.variable(ctx, STA_W, target) :+ AssemblyLine.accu8)
|
AssemblyLine.accu16 :: (AssemblyLine.variable(ctx, LDA_W, source) ++ AssemblyLine.variable(ctx, STA_W, target) :+ AssemblyLine.accu8)
|
||||||
} else {
|
} else {
|
||||||
val copyFromLo = List.tabulate(exprType.size)(i => AssemblyLine.variable(ctx, LDA, source, i) ++ AssemblyLine.variable(ctx, STA, target, i))
|
val copyFromLo = List.tabulate(exprType.size)(i => AssemblyLine.variable(ctx, LDA, source, i) ++ AssemblyLine.variable(ctx, STA, target, i))
|
||||||
|
@ -785,12 +785,18 @@ object MosAssembler {
|
|||||||
na(LDA, LongIndexedY, 0xB7)
|
na(LDA, LongIndexedY, 0xB7)
|
||||||
na(LDA, LongAbsolute, 0xAF)
|
na(LDA, LongAbsolute, 0xAF)
|
||||||
na(LDA, LongAbsoluteX, 0xBF)
|
na(LDA, LongAbsoluteX, 0xBF)
|
||||||
em(CMP, Stack, 0xA3)
|
em(CMP, Stack, 0xC3)
|
||||||
em(CMP, IndexedSY, 0xB3)
|
em(CMP, IndexedSY, 0xD3)
|
||||||
na(CMP, LongIndexedZ, 0xA7)
|
na(CMP, LongIndexedZ, 0xC7)
|
||||||
na(CMP, LongIndexedY, 0xB7)
|
na(CMP, LongIndexedY, 0xD7)
|
||||||
na(CMP, LongAbsolute, 0xAF)
|
na(CMP, LongAbsolute, 0xCF)
|
||||||
na(CMP, LongAbsoluteX, 0xBF)
|
na(CMP, LongAbsoluteX, 0xDF)
|
||||||
|
em(SBC, Stack, 0xE3)
|
||||||
|
em(SBC, IndexedSY, 0xF3)
|
||||||
|
na(SBC, LongIndexedZ, 0xE7)
|
||||||
|
na(SBC, LongIndexedY, 0xF7)
|
||||||
|
na(SBC, LongAbsolute, 0xEF)
|
||||||
|
na(SBC, LongAbsoluteX, 0xFF)
|
||||||
|
|
||||||
em(COP, Immediate, 0x02)
|
em(COP, Immediate, 0x02)
|
||||||
em(XBA, Implied, 0xEB)
|
em(XBA, Implied, 0xEB)
|
||||||
|
@ -10,6 +10,7 @@ object EmuUnoptimizedCrossPlatformRun {
|
|||||||
def apply(platforms: Cpu.Value*)(source: String)(verifier: MemoryBank => Unit): Unit = {
|
def apply(platforms: Cpu.Value*)(source: String)(verifier: MemoryBank => Unit): Unit = {
|
||||||
val (_, mm) = if (platforms.contains(Cpu.Mos) || platforms.contains(Cpu.StrictMos)) EmuUnoptimizedRun.apply2(source) else Timings(-1, -1) -> null
|
val (_, mm) = if (platforms.contains(Cpu.Mos) || platforms.contains(Cpu.StrictMos)) EmuUnoptimizedRun.apply2(source) else Timings(-1, -1) -> null
|
||||||
val (_, mc) = if (platforms.contains(Cpu.Cmos)) EmuUnoptimizedCmosRun.apply2(source) else Timings(-1, -1) -> null
|
val (_, mc) = if (platforms.contains(Cpu.Cmos)) EmuUnoptimizedCmosRun.apply2(source) else Timings(-1, -1) -> null
|
||||||
|
val (_, ma) = if (platforms.contains(Cpu.Sixteen)) EmuUnoptimizedNative65816Run.apply2(source) else Timings(-1, -1) -> null
|
||||||
val (_, mn) = if (platforms.contains(Cpu.Ricoh)) EmuUnoptimizedRicohRun.apply2(source) else Timings(-1, -1) -> null
|
val (_, mn) = if (platforms.contains(Cpu.Ricoh)) EmuUnoptimizedRicohRun.apply2(source) else Timings(-1, -1) -> null
|
||||||
val (_, mz) = if (platforms.contains(Cpu.Z80)) EmuUnoptimizedZ80Run.apply2(source) else Timings(-1, -1) -> null
|
val (_, mz) = if (platforms.contains(Cpu.Z80)) EmuUnoptimizedZ80Run.apply2(source) else Timings(-1, -1) -> null
|
||||||
val (_, mi) = if (platforms.contains(Cpu.Intel8080)) EmuUnoptimizedIntel8080Run.apply2(source) else Timings(-1, -1) -> null
|
val (_, mi) = if (platforms.contains(Cpu.Intel8080)) EmuUnoptimizedIntel8080Run.apply2(source) else Timings(-1, -1) -> null
|
||||||
@ -24,6 +25,10 @@ object EmuUnoptimizedCrossPlatformRun {
|
|||||||
println(f"Running Ricoh")
|
println(f"Running Ricoh")
|
||||||
verifier(mn)
|
verifier(mn)
|
||||||
}
|
}
|
||||||
|
if (Settings.enableWdc85816Tests && platforms.contains(Cpu.Sixteen)) {
|
||||||
|
println(f"Running 65816")
|
||||||
|
verifier(ma)
|
||||||
|
}
|
||||||
if (Settings.enable65C02Tests && platforms.contains(Cpu.Cmos)) {
|
if (Settings.enable65C02Tests && platforms.contains(Cpu.Cmos)) {
|
||||||
println(f"Running 65C02")
|
println(f"Running 65C02")
|
||||||
verifier(mc)
|
verifier(mc)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user