]> Git Repo - qemu.git/commitdiff
ppc: BOOK3E: nothing should be done when MSR:PR is set
authorVladimir Svoboda <[email protected]>
Thu, 17 Nov 2016 13:49:48 +0000 (14:49 +0100)
committerDavid Gibson <[email protected]>
Wed, 23 Nov 2016 01:00:48 +0000 (12:00 +1100)
The server architecture (BOOK3S) specifies that any instruction that
sets MSR:PR will also set MSR:EE, IR and DR.
However there is no such behavior specification for the embedded
architecture (BOOK3E).

Signed-off-by: Vladimir Svoboda <[email protected]>
Signed-off-by: David Gibson <[email protected]>
Reviewed-by: Thomas Huth <[email protected]>
target-ppc/helper_regs.h

index bb9ce60436a1d3ce7d7e00727182b8c95e74c5bd..62138163a585e543c874acc7266325fa763b5148 100644 (file)
@@ -131,11 +131,14 @@ static inline int hreg_store_msr(CPUPPCState *env, target_ulong value,
     }
     /* If PR=1 then EE, IR and DR must be 1
      *
-     * Note: We only enforce this on 64-bit processors. It appears that
-     * 32-bit implementations supports PR=1 and EE/DR/IR=0 and MacOS
-     * exploits it.
+     * Note: We only enforce this on 64-bit server processors.
+     * It appears that:
+     * - 32-bit implementations supports PR=1 and EE/DR/IR=0 and MacOS
+     *   exploits it.
+     * - 64-bit embedded implementations do not need any operation to be
+     *   performed when PR is set.
      */
-    if ((env->insns_flags & PPC_64B) && ((value >> MSR_PR) & 1)) {
+    if ((env->insns_flags & PPC_SEGMENT_64B) && ((value >> MSR_PR) & 1)) {
         value |= (1 << MSR_EE) | (1 << MSR_DR) | (1 << MSR_IR);
     }
 #endif
This page took 0.027578 seconds and 4 git commands to generate.