1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-27 04:57:45 +00:00

LibJIT: Emit 8-bit displacement variants for mov when possible

This commit is contained in:
Andreas Kling 2023-10-26 15:29:42 +02:00
parent d09bc54586
commit fb483f1950

View file

@ -140,8 +140,13 @@ struct Assembler {
| ((to_underlying(src.reg) >= 8) ? 1 << 2 : 0) | ((to_underlying(src.reg) >= 8) ? 1 << 2 : 0)
| ((to_underlying(dst.reg) >= 8) ? 1 << 0 : 0)); | ((to_underlying(dst.reg) >= 8) ? 1 << 0 : 0));
emit8(0x89); emit8(0x89);
if (dst.offset_or_immediate <= 127) {
emit8(0x40 | (encode_reg(src.reg) << 3) | encode_reg(dst.reg));
emit8(dst.offset_or_immediate);
} else {
emit8(0x80 | (encode_reg(src.reg) << 3) | encode_reg(dst.reg)); emit8(0x80 | (encode_reg(src.reg) << 3) | encode_reg(dst.reg));
emit32(dst.offset_or_immediate); emit32(dst.offset_or_immediate);
}
return; return;
} }
@ -150,8 +155,13 @@ struct Assembler {
| ((to_underlying(dst.reg) >= 8) ? 1 << 2 : 0) | ((to_underlying(dst.reg) >= 8) ? 1 << 2 : 0)
| ((to_underlying(src.reg) >= 8) ? 1 << 0 : 0)); | ((to_underlying(src.reg) >= 8) ? 1 << 0 : 0));
emit8(0x8b); emit8(0x8b);
if (src.offset_or_immediate <= 127) {
emit8(0x40 | (encode_reg(dst.reg) << 3) | encode_reg(src.reg));
emit8(src.offset_or_immediate);
} else {
emit8(0x80 | (encode_reg(dst.reg) << 3) | encode_reg(src.reg)); emit8(0x80 | (encode_reg(dst.reg) << 3) | encode_reg(src.reg));
emit32(src.offset_or_immediate); emit32(src.offset_or_immediate);
}
return; return;
} }