From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:53571) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1WyKsQ-0002Nv-DV for qemu-devel@nongnu.org; Sat, 21 Jun 2014 08:58:45 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1WyKsJ-0007SC-5u for qemu-devel@nongnu.org; Sat, 21 Jun 2014 08:58:38 -0400 Received: from mail-we0-x236.google.com ([2a00:1450:400c:c03::236]:48313) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1WyKsI-0007R5-V5 for qemu-devel@nongnu.org; Sat, 21 Jun 2014 08:58:31 -0400 Received: by mail-we0-f182.google.com with SMTP id q59so4947466wes.27 for ; Sat, 21 Jun 2014 05:58:30 -0700 (PDT) Sender: Paolo Bonzini From: Paolo Bonzini Date: Sat, 21 Jun 2014 14:58:11 +0200 Message-Id: <1403355502-12288-1-git-send-email-pbonzini@redhat.com> Subject: [Qemu-devel] [PATCH v3 00/11] implement dynamic endianness switching List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: peter.maydell@linaro.org This fixes the Raspberry Pi optimized memcmp library (with both user-mode and system-mode emulation). Compared to the previous submission, the main changes are: - I track access endianness by taking into account both SCTLR.B and CPSR.E, to make the code easier to understand (though a little bit more convoluted) - because of this, I prevent execution of BE32 executables with ARMv7 or v8 CPUs. These CPUs do not have SCTLR.B. - because of this, I also included an untested patch to implement BE32 mode in system emulation (BE8 should already work with the previous versions of the series). Note that I also tested the rest only with BE32, since BE8 is not included in linux-user-test-0.3 (it may be possible to convert BE32 to BE8 using ld -r? I haven't tried yet and I'm going to travel for the rest of the weekend). It is a bit late for 2.1, so I wouldn't complain if this is pushed out to the next version. Thanks, Paolo Paolo Bonzini (11): linux-user: arm: fix coding style for some linux-user signal functions linux-user: arm: pass env to get_user_code_* target-arm: implement SCTLR.B, drop bswap_code linux-user: arm: set CPSR.E correctly for BE8 mode linux-user: arm: handle CPSR.E correctly in strex emulation target-arm: implement SCTLR.EE target-arm: pass DisasContext to gen_aa32_ld*/st* target-arm: introduce tbflag for CPSR.E target-arm: implement setend target-arm: reorganize gen_aa32_ld/st to prepare for BE32 system emulation target-arm: implement BE32 mode in system emulation linux-user/arm/target_cpu.h | 2 + linux-user/main.c | 81 ++++++-- linux-user/signal.c | 114 ++++++------ target-arm/arm_ldst.h | 8 +- target-arm/cpu.h | 85 ++++++++- target-arm/helper.c | 46 ++++- target-arm/helper.h | 1 + target-arm/op_helper.c | 5 + target-arm/translate-a64.c | 6 +- target-arm/translate.c | 444 +++++++++++++++++++++++++++----------------- target-arm/translate.h | 4 +- 11 files changed, 525 insertions(+), 271 deletions(-) -- 1.9.3