From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([140.186.70.92]:37696) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1RllMg-0001dc-8L for qemu-devel@nongnu.org; Fri, 13 Jan 2012 12:56:34 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1RllMc-0002QG-7T for qemu-devel@nongnu.org; Fri, 13 Jan 2012 12:56:34 -0500 Received: from mnementh.archaic.org.uk ([81.2.115.146]:38700) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1RllMb-0002Q7-VT for qemu-devel@nongnu.org; Fri, 13 Jan 2012 12:56:30 -0500 From: Peter Maydell Date: Fri, 13 Jan 2012 17:50:38 +0000 Message-Id: <1326477039-12087-2-git-send-email-peter.maydell@linaro.org> In-Reply-To: <1326477039-12087-1-git-send-email-peter.maydell@linaro.org> References: <1326477039-12087-1-git-send-email-peter.maydell@linaro.org> Subject: [Qemu-devel] [PATCH 1/2] target-arm: Fix errors in decode of M profile CPS List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Aurelien Jarno , Blue Swirl Cc: qemu-devel@nongnu.org Fix errors in the decode of M profile CPS: * the decode of the I (affects PRIMASK) and F (affects FAULTMASK) bits was reversed * the FAULTMASK system register number is 19, not 17 This fixes an issue reported as LP:913925. Signed-off-by: Peter Maydell --- target-arm/translate.c | 8 ++++---- 1 files changed, 4 insertions(+), 4 deletions(-) diff --git a/target-arm/translate.c b/target-arm/translate.c index f91553a..280bfca 100644 --- a/target-arm/translate.c +++ b/target-arm/translate.c @@ -9710,15 +9710,15 @@ static void disas_thumb_insn(CPUState *env, DisasContext *s) break; if (IS_M(env)) { tmp = tcg_const_i32((insn & (1 << 4)) != 0); - /* PRIMASK */ + /* FAULTMASK */ if (insn & 1) { - addr = tcg_const_i32(16); + addr = tcg_const_i32(19); gen_helper_v7m_msr(cpu_env, addr, tmp); tcg_temp_free_i32(addr); } - /* FAULTMASK */ + /* PRIMASK */ if (insn & 2) { - addr = tcg_const_i32(17); + addr = tcg_const_i32(16); gen_helper_v7m_msr(cpu_env, addr, tmp); tcg_temp_free_i32(addr); } -- 1.7.1