From 59882cf765eab2851222b928183d411df3ceadf4 Mon Sep 17 00:00:00 2001 From: Karol Stasiak Date: Thu, 26 Mar 2020 01:38:54 +0100 Subject: [PATCH] 6502: Fix zp allocation --- src/main/scala/millfork/env/Environment.scala | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/main/scala/millfork/env/Environment.scala b/src/main/scala/millfork/env/Environment.scala index b94b1b08..0d9b7aa1 100644 --- a/src/main/scala/millfork/env/Environment.scala +++ b/src/main/scala/millfork/env/Environment.scala @@ -152,7 +152,10 @@ class Environment(val parent: Option[Environment], val prefix: String, val cpuFa case VariableAllocationMethod.Register => 2 case _ => 3 } else 3 - val toAdd = things.values.flatMap { + + def prioritize[T](list: List[T])(hasPriority: T => Boolean): List[T] = list.filter(hasPriority) ++ list.filterNot(hasPriority) + + val toAdd = prioritize(things.values.toList)(th => th.name =="__reg").flatMap { case m: UninitializedMemory if passForAlloc(m.alloc) == pass && nf.isDefined == isLocalVariableName(m.name) && !m.name.endsWith(".addr") && maybeGet[Thing](m.name + ".array").isEmpty => if (log.traceEnabled) log.trace("Allocating " + m.name) val vertex = if (options.flag(CompilationFlag.VariableOverlap)) { @@ -1467,7 +1470,7 @@ class Environment(val parent: Option[Environment], val prefix: String, val cpuFa val p = get[Type]("pointer") stmt.assemblyParamPassingConvention match { case ByVariable(name) => - val zp = typ.isPointy || pointies(name) // TODO + val zp = pointies(name) // TODO val v = UninitializedMemoryVariable(prefix + name, typ, if (zp) VariableAllocationMethod.Zeropage else VariableAllocationMethod.Auto, None, defaultVariableAlignment(options, 2), isVolatile = false) addThing(v, stmt.position) registerAddressConstant(v, stmt.position, options, Some(typ))