fixed some array codegen issues

This commit is contained in:
Irmen de Jong 2019-08-09 02:15:31 +02:00
parent c79b587eea
commit 3466106119
7 changed files with 131 additions and 37 deletions

View File

@ -857,7 +857,7 @@ internal class AstChecker(private val program: Program,
} }
} }
if(target.name=="swap") { if(target.name=="swap") {
// swap() is a bit weird because this one is translated into a sequence of bytecodes, instead of being an actual function call // swap() is a bit weird because this one is translated into a operations directly, instead of being a function call
val dt1 = args[0].inferType(program)!! val dt1 = args[0].inferType(program)!!
val dt2 = args[1].inferType(program)!! val dt2 = args[1].inferType(program)!!
if (dt1 != dt2) if (dt1 != dt2)

View File

@ -298,7 +298,6 @@ internal class StatementReorderer(private val program: Program): IAstModifyingVi
} }
} }
is BuiltinFunctionStatementPlaceholder -> { is BuiltinFunctionStatementPlaceholder -> {
// if(sub.name in setOf("lsl", "lsr", "rol", "ror", "rol2", "ror2", "memset", "memcopy", "memsetw", "swap"))
val func = BuiltinFunctions.getValue(sub.name) val func = BuiltinFunctions.getValue(sub.name)
if(func.pure) { if(func.pure) {
// non-pure functions don't get automatic typecasts because sometimes they act directly on their parameters // non-pure functions don't get automatic typecasts because sometimes they act directly on their parameters

View File

@ -582,7 +582,7 @@ internal class AsmGen2(val program: Program,
} }
} }
private fun translate(stmt: Statement) { internal fun translate(stmt: Statement) {
outputSourceLine(stmt) outputSourceLine(stmt)
when(stmt) { when(stmt) {
is VarDecl, is StructDecl, is NopStatement -> {} is VarDecl, is StructDecl, is NopStatement -> {}
@ -2172,7 +2172,7 @@ $endLabel""")
} }
} }
private fun assignFromEvalResult(target: AssignTarget) { internal fun assignFromEvalResult(target: AssignTarget) {
val targetIdent = target.identifier val targetIdent = target.identifier
when { when {
target.register!=null -> { target.register!=null -> {
@ -2580,7 +2580,34 @@ $endLabel""")
targetArrayIdx!=null -> { targetArrayIdx!=null -> {
val index = targetArrayIdx.arrayspec.index val index = targetArrayIdx.arrayspec.index
val targetName = asmIdentifierName(targetArrayIdx.identifier) val targetName = asmIdentifierName(targetArrayIdx.identifier)
TODO("assign float 0.0 to array $targetName [ $index ]") if(index is NumericLiteralValue) {
val indexValue = index.number.toInt() * MachineDefinition.Mflpt5.MemorySize
out("""
lda #0
sta $targetName+$indexValue
sta $targetName+$indexValue+1
sta $targetName+$indexValue+2
sta $targetName+$indexValue+3
sta $targetName+$indexValue+4
""")
} else {
translateExpression(index)
out("""
inx
lda $ESTACK_LO_HEX,x
asl a
asl a
clc
adc $ESTACK_LO_HEX,x
tay
lda #0
sta $targetName,y
sta $targetName+1,y
sta $targetName+2,y
sta $targetName+3,y
sta $targetName+4,y
""") // TODO use a subroutine for this
}
} }
else -> TODO("assign float 0.0 to $target") else -> TODO("assign float 0.0 to $target")
} }
@ -2608,7 +2635,18 @@ $endLabel""")
val arrayVarName = asmIdentifierName(targetArrayIdx.identifier) val arrayVarName = asmIdentifierName(targetArrayIdx.identifier)
if(index is NumericLiteralValue) { if(index is NumericLiteralValue) {
val indexValue = index.number.toInt() * MachineDefinition.Mflpt5.MemorySize val indexValue = index.number.toInt() * MachineDefinition.Mflpt5.MemorySize
out(" lda #<$arrayVarName+$indexValue | ldy #>$arrayVarName+$indexValue | jsr c64flt.pop_float") out("""
lda $constFloat
sta $arrayVarName+$indexValue
lda $constFloat+1
sta $arrayVarName+$indexValue+1
lda $constFloat+2
sta $arrayVarName+$indexValue+2
lda $constFloat+3
sta $arrayVarName+$indexValue+3
lda $constFloat+4
sta $arrayVarName+$indexValue+4
""")
} else { } else {
translateArrayIndexIntoA(targetArrayIdx) translateArrayIndexIntoA(targetArrayIdx)
out(""" out("""

View File

@ -89,7 +89,6 @@ fun optimizeUselessStackByteWrites(linesByFour: List<List<IndexedValue<String>>>
lines[1].value.trim()=="dex" && lines[1].value.trim()=="dex" &&
lines[2].value.trim()=="inx" && lines[2].value.trim()=="inx" &&
lines[3].value.trim()=="lda $ESTACK_LO_HEX,x") { lines[3].value.trim()=="lda $ESTACK_LO_HEX,x") {
removeLines.add(lines[0].index)
removeLines.add(lines[1].index) removeLines.add(lines[1].index)
removeLines.add(lines[2].index) removeLines.add(lines[2].index)
removeLines.add(lines[3].index) removeLines.add(lines[3].index)

View File

@ -7,6 +7,9 @@ import prog8.ast.base.DataType
import prog8.ast.base.Register import prog8.ast.base.Register
import prog8.ast.base.WordDatatypes import prog8.ast.base.WordDatatypes
import prog8.ast.expressions.* import prog8.ast.expressions.*
import prog8.ast.statements.AssignTarget
import prog8.ast.statements.Assignment
import prog8.ast.statements.DirectMemoryWrite
import prog8.ast.statements.FunctionCallStatement import prog8.ast.statements.FunctionCallStatement
import prog8.compiler.CompilationOptions import prog8.compiler.CompilationOptions
import prog8.compiler.Zeropage import prog8.compiler.Zeropage
@ -67,6 +70,17 @@ internal class BuiltinFunctionsAsmGen(private val program: Program,
else -> throw AssemblyError("weird type") else -> throw AssemblyError("weird type")
} }
} }
"swap" -> {
val first = fcall.arglist[0]
val second = fcall.arglist[1]
asmgen.translateExpression(first)
asmgen.translateExpression(second)
// pop in reverse order
val firstTarget = AssignTarget.fromExpr(first)
val secondTarget = AssignTarget.fromExpr(second)
asmgen.assignFromEvalResult(firstTarget)
asmgen.assignFromEvalResult(secondTarget)
}
// TODO: any(f), all(f), max(f), min(f), sum(f) // TODO: any(f), all(f), max(f), min(f), sum(f)
"sin", "cos", "tan", "atan", "sin", "cos", "tan", "atan",
"ln", "log2", "sqrt", "rad", "ln", "log2", "sqrt", "rad",

View File

@ -1,17 +1,57 @@
%import c64utils %import c64utils
%import c64lib %import c64lib
%import c64flt
%zeropage dontuse %zeropage dontuse
main { main {
sub start() { sub start() {
for ubyte ub1 in 10 to 20 { ubyte ub1 = 123
for ubyte ub2 in ub1 to 30 { ubyte ub2 = 222
c64scr.print_ub(ub2) uword uw = 1111
c64.CHROUT(',') uword uw2 = 2222
} word[] warr = [1111, 2222]
c64.CHROUT('\n') float[] farr = [1.111, 2.222]
}
c64scr.print_ub(ub1)
c64.CHROUT(',')
c64scr.print_ub(ub2)
c64.CHROUT('\n')
c64scr.print_uw(uw)
c64.CHROUT(',')
c64scr.print_uw(uw2)
c64.CHROUT('\n')
c64scr.print_w(warr[0])
c64.CHROUT(',')
c64scr.print_w(warr[1])
c64.CHROUT('\n')
c64flt.print_f(farr[0])
c64.CHROUT(',')
c64flt.print_f(farr[1])
c64.CHROUT('\n')
swap(ub1, ub2)
swap(uw,uw2)
swap(warr[0], warr[1])
swap(farr[0], farr[1]) ; TODO CRASHES
c64scr.print_ub(ub1)
c64.CHROUT(',')
c64scr.print_ub(ub2)
c64.CHROUT('\n')
c64scr.print_uw(uw)
c64.CHROUT(',')
c64scr.print_uw(uw2)
c64.CHROUT('\n')
c64scr.print_w(warr[0])
c64.CHROUT(',')
c64scr.print_w(warr[1])
c64.CHROUT('\n')
c64flt.print_f(farr[0])
c64.CHROUT(',')
c64flt.print_f(farr[1])
c64.CHROUT('\n')
} }
} }

View File

@ -2,6 +2,10 @@
%zeropage basicsafe %zeropage basicsafe
%option enable_floats %option enable_floats
; TODO complete codegeneration for all lines in this
main { main {
sub start() { sub start() {
@ -117,28 +121,28 @@ main {
muwarray[2] = uw muwarray[2] = uw
mflarray[2] = fl mflarray[2] = fl
; s1[A] = ub s1[A] = ub
; s2[A] = ub s2[A] = ub
; barray[A] = bb barray[A] = bb
; ubarray[A] = ub ubarray[A] = ub
; warray[A] = ww warray[A] = ww
; uwarray[A] = uw uwarray[A] = uw
; flarray[A] = fl flarray[A] = fl
;
; s1[bb] = ub s1[bb] = ub
; s2[bb] = ub s2[bb] = ub
; barray[bb] = bb barray[bb] = bb
; ubarray[bb] = ub ubarray[bb] = ub
; warray[bb] = ww warray[bb] = ww
; uwarray[bb] = uw uwarray[bb] = uw
; flarray[bb] = fl flarray[bb] = fl
;
; s1[bb*3] = ub s1[bb*3] = ub
; s2[bb*3] = ub s2[bb*3] = ub
; barray[bb*3] = bb barray[bb*3] = bb
; ubarray[bb*3] = ub ubarray[bb*3] = ub
; warray[bb*3] = ww warray[bb*3] = ww
; uwarray[bb*3] = uw uwarray[bb*3] = uw
; flarray[bb*3] = fl flarray[bb*3] = fl
} }
} }