[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v3 03/12] target-arm: A64: provide functions for acc
From: |
Peter Maydell |
Subject: |
[Qemu-devel] [PATCH v3 03/12] target-arm: A64: provide functions for accessing FPCR and FPSR |
Date: |
Thu, 5 Dec 2013 12:39:31 +0000 |
The information which AArch32 holds in the FPSCR is split for
AArch64 into two logically distinct registers, FPSR and FPCR.
Since they are carefully arranged to use non-overlapping bits,
we leave the underlying state in the same place, and provide
accessor functions which just update the appropriate bits
via vfp_get_fpscr() and vfp_set_fpscr().
Signed-off-by: Peter Maydell <address@hidden>
Reviewed-by: Richard Henderson <address@hidden>
---
target-arm/cpu.h | 28 ++++++++++++++++++++++++++++
1 file changed, 28 insertions(+)
diff --git a/target-arm/cpu.h b/target-arm/cpu.h
index ff7aac5..4807354 100644
--- a/target-arm/cpu.h
+++ b/target-arm/cpu.h
@@ -445,6 +445,34 @@ static inline void xpsr_write(CPUARMState *env, uint32_t
val, uint32_t mask)
uint32_t vfp_get_fpscr(CPUARMState *env);
void vfp_set_fpscr(CPUARMState *env, uint32_t val);
+/* For A64 the FPSCR is split into two logically distinct registers,
+ * FPCR and FPSR. However since they still use non-overlapping bits
+ * we store the underlying state in fpscr and just mask on read/write.
+ */
+#define FPSR_MASK 0xf800009f
+#define FPCR_MASK 0x07f79f00
+static inline uint32_t vfp_get_fpsr(CPUARMState *env)
+{
+ return vfp_get_fpscr(env) & FPSR_MASK;
+}
+
+static inline void vfp_set_fpsr(CPUARMState *env, uint32_t val)
+{
+ uint32_t new_fpscr = (vfp_get_fpscr(env) & ~FPSR_MASK) | (val & FPSR_MASK);
+ vfp_set_fpscr(env, new_fpscr);
+}
+
+static inline uint32_t vfp_get_fpcr(CPUARMState *env)
+{
+ return vfp_get_fpscr(env) & FPCR_MASK;
+}
+
+static inline void vfp_set_fpcr(CPUARMState *env, uint32_t val)
+{
+ uint32_t new_fpscr = (vfp_get_fpscr(env) & ~FPCR_MASK) | (val & FPCR_MASK);
+ vfp_set_fpscr(env, new_fpscr);
+}
+
enum arm_cpu_mode {
ARM_CPU_MODE_USR = 0x10,
ARM_CPU_MODE_FIQ = 0x11,
--
1.7.9.5
- [Qemu-devel] [PATCH v3 00/12] target-arm: A64 decoder, foundation plus branches, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 09/12] target-arm: A64: add support for BR, BLR and RET insns, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 10/12] target-arm: A64: add support for conditional branches, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 02/12] target-arm: A64: add set_pc cpu method, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 06/12] target-arm: A64: provide skeleton for a64 insn decoding, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 12/12] target-arm: A64: add support for compare and branch imm, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 03/12] target-arm: A64: provide functions for accessing FPCR and FPSR,
Peter Maydell <=
- [Qemu-devel] [PATCH v3 07/12] target-arm: A64: expand decoding skeleton for system instructions, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 01/12] target-arm: Split A64 from A32/T32 gen_intermediate_code_internal(), Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 04/12] target-arm: Support fp registers in gdb stub, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 05/12] target-arm: A64: add stubs for a64 specific helpers, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 11/12] target-arm: A64: add support for 'test and branch' imm, Peter Maydell, 2013/12/05
- [Qemu-devel] [PATCH v3 08/12] target-arm: A64: add support for B and BL insns, Peter Maydell, 2013/12/05
- Re: [Qemu-devel] [PATCH v3 00/12] target-arm: A64 decoder, foundation plus branches, Peter Maydell, 2013/12/17