mirror of
https://github.com/qemu/qemu.git
synced 2025-08-08 08:05:17 +00:00
tcg/mips: Mask TCGMemOp appropriately for indexing
Commit 2b7ec66f
fixed TCGMemOp masking following the MO_AMASK addition,
but two cases were forgotten in the TCG MIPS backend.
Reviewed-by: Richard Henderson <rth@twiddle.net>
Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
This commit is contained in:
parent
e72c4fb81d
commit
4214a8cb7c
@ -1105,7 +1105,7 @@ static void tcg_out_qemu_st_slow_path(TCGContext *s, TCGLabelQemuLdst *l)
|
|||||||
static void tcg_out_qemu_ld_direct(TCGContext *s, TCGReg datalo, TCGReg datahi,
|
static void tcg_out_qemu_ld_direct(TCGContext *s, TCGReg datalo, TCGReg datahi,
|
||||||
TCGReg base, TCGMemOp opc)
|
TCGReg base, TCGMemOp opc)
|
||||||
{
|
{
|
||||||
switch (opc) {
|
switch (opc & (MO_SSIZE | MO_BSWAP)) {
|
||||||
case MO_UB:
|
case MO_UB:
|
||||||
tcg_out_opc_imm(s, OPC_LBU, datalo, base, 0);
|
tcg_out_opc_imm(s, OPC_LBU, datalo, base, 0);
|
||||||
break;
|
break;
|
||||||
@ -1195,7 +1195,7 @@ static void tcg_out_qemu_ld(TCGContext *s, const TCGArg *args, bool is_64)
|
|||||||
static void tcg_out_qemu_st_direct(TCGContext *s, TCGReg datalo, TCGReg datahi,
|
static void tcg_out_qemu_st_direct(TCGContext *s, TCGReg datalo, TCGReg datahi,
|
||||||
TCGReg base, TCGMemOp opc)
|
TCGReg base, TCGMemOp opc)
|
||||||
{
|
{
|
||||||
switch (opc) {
|
switch (opc & (MO_SIZE | MO_BSWAP)) {
|
||||||
case MO_8:
|
case MO_8:
|
||||||
tcg_out_opc_imm(s, OPC_SB, datalo, base, 0);
|
tcg_out_opc_imm(s, OPC_SB, datalo, base, 0);
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user