From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:41166) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1ZKvvr-0006uJ-HC for qemu-devel@nongnu.org; Thu, 30 Jul 2015 18:04:08 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1ZKvvp-0002L8-Hl for qemu-devel@nongnu.org; Thu, 30 Jul 2015 18:04:07 -0400 Received: from hall.aurel32.net ([2001:bc8:30d7:100::1]:40062) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1ZKvvp-0002KU-CW for qemu-devel@nongnu.org; Thu, 30 Jul 2015 18:04:05 -0400 From: Aurelien Jarno Date: Fri, 31 Jul 2015 00:04:00 +0200 Message-Id: <1438293840-7569-4-git-send-email-aurelien@aurel32.net> In-Reply-To: <1438293840-7569-1-git-send-email-aurelien@aurel32.net> References: <1438293840-7569-1-git-send-email-aurelien@aurel32.net> Subject: [Qemu-devel] [PATCH 3/3] tcg/s390x: Mask TCGMemOp appropriately for indexing List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: Aurelien Jarno , Richard Henderson Commit 2b7ec66f fixed TCGMemOp masking following the MO_AMASK addition, but two cases were forgotten in the TCG S390 backend. Cc: Richard Henderson Signed-off-by: Aurelien Jarno --- tcg/s390/tcg-target.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tcg/s390/tcg-target.c b/tcg/s390/tcg-target.c index 921991e..aa718ec 100644 --- a/tcg/s390/tcg-target.c +++ b/tcg/s390/tcg-target.c @@ -1390,7 +1390,7 @@ static void tcg_out_call(TCGContext *s, tcg_insn_unit *dest) static void tcg_out_qemu_ld_direct(TCGContext *s, TCGMemOp opc, TCGReg data, TCGReg base, TCGReg index, int disp) { - switch (opc) { + switch (opc & (MO_SSIZE | MO_BSWAP)) { case MO_UB: tcg_out_insn(s, RXY, LLGC, data, base, index, disp); break; @@ -1449,7 +1449,7 @@ static void tcg_out_qemu_ld_direct(TCGContext *s, TCGMemOp opc, TCGReg data, static void tcg_out_qemu_st_direct(TCGContext *s, TCGMemOp opc, TCGReg data, TCGReg base, TCGReg index, int disp) { - switch (opc) { + switch (opc & (MO_SIZE | MO_BSWAP)) { case MO_UB: if (disp >= 0 && disp < 0x1000) { tcg_out_insn(s, RX, STC, data, base, index, disp); -- 2.1.4