codegen.c: fixed a bug in `OP_LOADI32` peephole optimization.

parent 598c97ef
...@@ -488,11 +488,19 @@ gen_move(codegen_scope *s, uint16_t dst, uint16_t src, int nopeep) ...@@ -488,11 +488,19 @@ gen_move(codegen_scope *s, uint16_t dst, uint16_t src, int nopeep)
s->pc = s->lastpc; s->pc = s->lastpc;
genop_2(s, data.insn, dst, data.b); genop_2(s, data.insn, dst, data.b);
break; break;
case OP_GETUPVAR: case OP_LOADI32: case OP_GETUPVAR:
if (nopeep || data.a != src || data.a < s->nlocals) goto normal; if (nopeep || data.a != src || data.a < s->nlocals) goto normal;
s->pc = s->lastpc; s->pc = s->lastpc;
genop_3(s, data.insn, dst, data.b, data.c); genop_3(s, data.insn, dst, data.b, data.c);
break; break;
case OP_LOADI32:
if (nopeep || data.a != src || data.a < s->nlocals) goto normal;
else {
uint32_t i = (uint32_t)data.b<<16|data.c;
s->pc = s->lastpc;
genop_2SS(s, data.insn, dst, i);
}
break;
default: default:
goto normal; goto normal;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment