mirror of
https://github.com/KarolS/millfork.git
synced 2025-01-08 22:30:34 +00:00
Fix some codegen bugs on 6502
This commit is contained in:
parent
6f294d6dec
commit
1bc1ab3539
@ -74,11 +74,17 @@ object BuiltIns {
|
|||||||
case FunctionCallExpression(name, List(param)) if env.maybeGet[Type](name).isDefined =>
|
case FunctionCallExpression(name, List(param)) if env.maybeGet[Type](name).isDefined =>
|
||||||
return simpleOperation(opcode, ctx, param, indexChoice, preserveA, commutative, decimal)
|
return simpleOperation(opcode, ctx, param, indexChoice, preserveA, commutative, decimal)
|
||||||
case _: FunctionCallExpression | _: SumExpression if commutative =>
|
case _: FunctionCallExpression | _: SumExpression if commutative =>
|
||||||
|
val code = MosExpressionCompiler.compileToA(ctx, source)
|
||||||
|
if (ctx.options.flags(CompilationFlag.IdentityPage)
|
||||||
|
&& !code.exists(_.concernsX)
|
||||||
|
&& AssemblyLine.treatment(code, State.X) == Treatment.Unchanged) {
|
||||||
|
return List(AssemblyLine.implied(TAX)) ++ code ++ wrapInSedCldIfNeeded(decimal, List(AssemblyLine.absoluteX(opcode, env.identityPage)))
|
||||||
|
}
|
||||||
// TODO: is it ok?
|
// TODO: is it ok?
|
||||||
if (ctx.options.zpRegisterSize >= 1) {
|
if (ctx.options.zpRegisterSize >= 1) {
|
||||||
val reg = ctx.env.get[ThingInMemory]("__reg")
|
val reg = ctx.env.get[ThingInMemory]("__reg")
|
||||||
return List(AssemblyLine.implied(PHA)) ++
|
return List(AssemblyLine.implied(PHA)) ++
|
||||||
MosExpressionCompiler.compileToA(ctx, source) ++
|
MosExpressionCompiler.fixTsx(code) ++
|
||||||
List(AssemblyLine.zeropage(STA, reg), AssemblyLine.implied(PLA)) ++
|
List(AssemblyLine.zeropage(STA, reg), AssemblyLine.implied(PLA)) ++
|
||||||
wrapInSedCldIfNeeded(decimal, List(AssemblyLine.zeropage(opcode, reg)))
|
wrapInSedCldIfNeeded(decimal, List(AssemblyLine.zeropage(opcode, reg)))
|
||||||
} else if (ctx.options.flag(CompilationFlag.EmitEmulation65816Opcodes)) {
|
} else if (ctx.options.flag(CompilationFlag.EmitEmulation65816Opcodes)) {
|
||||||
|
@ -72,6 +72,7 @@ object MosExpressionCompiler extends AbstractExpressionCompiler[AssemblyLine] {
|
|||||||
case 2 => if (ctx.options.flag(CompilationFlag.EmitNative65816Opcodes)) {
|
case 2 => if (ctx.options.flag(CompilationFlag.EmitNative65816Opcodes)) {
|
||||||
AssemblyLine.accu16 :: AssemblyLine(LDA_W, WordImmediate, expr) :: (AssemblyLine.variable(ctx, STA_W, m) :+ AssemblyLine.accu8)
|
AssemblyLine.accu16 :: AssemblyLine(LDA_W, WordImmediate, expr) :: (AssemblyLine.variable(ctx, STA_W, m) :+ AssemblyLine.accu8)
|
||||||
} else AssemblyLine.tsx(ctx) ++ List(
|
} else AssemblyLine.tsx(ctx) ++ List(
|
||||||
|
// TODO: ???
|
||||||
AssemblyLine.implied(TSX),
|
AssemblyLine.implied(TSX),
|
||||||
AssemblyLine.immediate(LDA, expr.loByte),
|
AssemblyLine.immediate(LDA, expr.loByte),
|
||||||
AssemblyLine.dataStackX(ctx, STA, offset),
|
AssemblyLine.dataStackX(ctx, STA, offset),
|
||||||
@ -155,10 +156,10 @@ object MosExpressionCompiler extends AbstractExpressionCompiler[AssemblyLine] {
|
|||||||
}
|
}
|
||||||
|
|
||||||
val cmos = ctx.options.flag(CompilationFlag.EmitCmosOpcodes)
|
val cmos = ctx.options.flag(CompilationFlag.EmitCmosOpcodes)
|
||||||
if (register == MosRegister.AX && !code.exists(_.concernsX)) {
|
if (register == MosRegister.AX && !code.exists(_.concernsX) && code.forall(_.treatment(State.X).==(Treatment.Unchanged))) {
|
||||||
return preserveRegisterIfNeeded(ctx, MosRegister.A, code)
|
return preserveRegisterIfNeeded(ctx, MosRegister.A, code)
|
||||||
}
|
}
|
||||||
if (register == MosRegister.AY && !code.exists(_.concernsY)) {
|
if (register == MosRegister.AY && !code.exists(_.concernsY) && code.forall(_.treatment(State.Y).==(Treatment.Unchanged))) {
|
||||||
return preserveRegisterIfNeeded(ctx, MosRegister.A, code)
|
return preserveRegisterIfNeeded(ctx, MosRegister.A, code)
|
||||||
}
|
}
|
||||||
if (states.exists(state => AssemblyLine.treatment(code, state) != Treatment.Unchanged)) {
|
if (states.exists(state => AssemblyLine.treatment(code, state) != Treatment.Unchanged)) {
|
||||||
@ -672,7 +673,11 @@ object MosExpressionCompiler extends AbstractExpressionCompiler[AssemblyLine] {
|
|||||||
}
|
}
|
||||||
case RegisterVariable(MosRegister.Y, _) => actualOffset match {
|
case RegisterVariable(MosRegister.Y, _) => actualOffset match {
|
||||||
case 0 => List(tsx)
|
case 0 => List(tsx)
|
||||||
case 1 => List(tsx, AssemblyLine.implied(TXA), AssemblyLine.implied(TAY), AssemblyLine.implied(INY))
|
case 1 =>
|
||||||
|
if (ctx.options.flag(CompilationFlag.IdentityPage))
|
||||||
|
List(tsx, AssemblyLine.absoluteX(LDY, ctx.env.identityPage), AssemblyLine.implied(INY))
|
||||||
|
else
|
||||||
|
List(tsx, AssemblyLine.implied(TXA), AssemblyLine.implied(TAY), AssemblyLine.implied(INY))
|
||||||
case _ => List(tsx, AssemblyLine.implied(TXA), AssemblyLine.implied(CLC), AssemblyLine.immediate(ADC, actualOffset), AssemblyLine.implied(TAY))
|
case _ => List(tsx, AssemblyLine.implied(TXA), AssemblyLine.implied(CLC), AssemblyLine.immediate(ADC, actualOffset), AssemblyLine.implied(TAY))
|
||||||
}
|
}
|
||||||
case _ =>
|
case _ =>
|
||||||
|
Loading…
Reference in New Issue
Block a user