mirror of
https://github.com/irmen/prog8.git
synced 2025-01-11 13:29:45 +00:00
fix compilation of large bitshifts
This commit is contained in:
parent
0adce9b9c6
commit
70ed2b4203
@ -590,7 +590,6 @@ internal class AssignmentAsmGen(private val program: PtProgram,
|
|||||||
assignExpressionToRegister(expr.left, RegisterOrPair.A, signed)
|
assignExpressionToRegister(expr.left, RegisterOrPair.A, signed)
|
||||||
when (shifts) {
|
when (shifts) {
|
||||||
in 0..7 -> {
|
in 0..7 -> {
|
||||||
require(dt==DataType.UBYTE)
|
|
||||||
if (expr.operator == "<<") {
|
if (expr.operator == "<<") {
|
||||||
repeat(shifts) {
|
repeat(shifts) {
|
||||||
asmgen.out(" asl a")
|
asmgen.out(" asl a")
|
||||||
@ -609,7 +608,7 @@ internal class AssignmentAsmGen(private val program: PtProgram,
|
|||||||
}
|
}
|
||||||
else -> {
|
else -> {
|
||||||
if(signed && expr.operator==">>") {
|
if(signed && expr.operator==">>") {
|
||||||
TODO("signed byte >> overshift should have been compiled away?")
|
asmgen.out(" ldy #$shifts | jsr math.lsr_byte_A")
|
||||||
} else {
|
} else {
|
||||||
asmgen.out(" lda #0")
|
asmgen.out(" lda #0")
|
||||||
}
|
}
|
||||||
@ -660,7 +659,7 @@ internal class AssignmentAsmGen(private val program: PtProgram,
|
|||||||
}
|
}
|
||||||
else -> {
|
else -> {
|
||||||
if(signed && expr.operator==">>") {
|
if(signed && expr.operator==">>") {
|
||||||
TODO("signed word >> overshift should have been compiled away?")
|
asmgen.out(" ldx #$shifts | jsr math.lsr_word_AY")
|
||||||
} else {
|
} else {
|
||||||
asmgen.out(" lda #0 | ldy #0")
|
asmgen.out(" lda #0 | ldy #0")
|
||||||
}
|
}
|
||||||
|
@ -235,6 +235,47 @@ class ConstantFoldingOptimizer(private val program: Program) : AstWalker() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(rightconst!=null && (expr.operator=="<<" || expr.operator==">>")) {
|
||||||
|
val dt = expr.left.inferType(program)
|
||||||
|
if(dt.isBytes && rightconst.number>=8) {
|
||||||
|
if(dt.istype(DataType.UBYTE)) {
|
||||||
|
val zeroUB = NumericLiteral(DataType.UBYTE, 0.0, expr.position)
|
||||||
|
modifications.add(IAstModification.ReplaceNode(expr, zeroUB, parent))
|
||||||
|
} else {
|
||||||
|
if(leftconst!=null) {
|
||||||
|
val zeroB = NumericLiteral(DataType.BYTE, 0.0, expr.position)
|
||||||
|
val minusoneB = NumericLiteral(DataType.BYTE, -1.0, expr.position)
|
||||||
|
if(leftconst.number<0.0) {
|
||||||
|
if(expr.operator=="<<")
|
||||||
|
modifications.add(IAstModification.ReplaceNode(expr, zeroB, parent))
|
||||||
|
else
|
||||||
|
modifications.add(IAstModification.ReplaceNode(expr, minusoneB, parent))
|
||||||
|
} else {
|
||||||
|
modifications.add(IAstModification.ReplaceNode(expr, zeroB, parent))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(dt.isWords && rightconst.number>=16) {
|
||||||
|
if(dt.istype(DataType.UWORD)) {
|
||||||
|
val zeroUW = NumericLiteral(DataType.UWORD, 0.0, expr.position)
|
||||||
|
modifications.add(IAstModification.ReplaceNode(expr, zeroUW, parent))
|
||||||
|
} else {
|
||||||
|
if(leftconst!=null) {
|
||||||
|
val zeroW = NumericLiteral(DataType.WORD, 0.0, expr.position)
|
||||||
|
val minusoneW = NumericLiteral(DataType.WORD, -1.0, expr.position)
|
||||||
|
if(leftconst.number<0.0) {
|
||||||
|
if(expr.operator=="<<")
|
||||||
|
modifications.add(IAstModification.ReplaceNode(expr, zeroW, parent))
|
||||||
|
else
|
||||||
|
modifications.add(IAstModification.ReplaceNode(expr, minusoneW, parent))
|
||||||
|
} else {
|
||||||
|
modifications.add(IAstModification.ReplaceNode(expr, zeroW, parent))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return modifications
|
return modifications
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user