提交 65d6c0f3 编写于 作者: J j_mayer

PowerPC SPE extension fix: must always preserve GPR high bits when

  running in 32 bits mode.


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3631 c046a42c-6fe2-441c-8c8c-71466251a162
上级 4f6cf9e8
...@@ -530,7 +530,7 @@ struct CPUPPCState { ...@@ -530,7 +530,7 @@ struct CPUPPCState {
/* general purpose registers */ /* general purpose registers */
ppc_gpr_t gpr[32]; ppc_gpr_t gpr[32];
#if TARGET_GPR_BITS < 64 #if !defined(TARGET_PPC64)
/* Storage for GPR MSB, used by the SPE extension */ /* Storage for GPR MSB, used by the SPE extension */
ppc_gpr_t gprh[32]; ppc_gpr_t gprh[32];
#endif #endif
......
...@@ -58,7 +58,7 @@ void OPPROTO glue(op_store_T2_gpr_gpr, REG) (void) ...@@ -58,7 +58,7 @@ void OPPROTO glue(op_store_T2_gpr_gpr, REG) (void)
#endif #endif
/* General purpose registers containing vector operands moves */ /* General purpose registers containing vector operands moves */
#if TARGET_GPR_BITS < 64 #if !defined(TARGET_PPC64)
void OPPROTO glue(op_load_gpr64_T0_gpr, REG) (void) void OPPROTO glue(op_load_gpr64_T0_gpr, REG) (void)
{ {
T0_64 = (uint64_t)env->gpr[REG] | ((uint64_t)env->gprh[REG] << 32); T0_64 = (uint64_t)env->gpr[REG] | ((uint64_t)env->gprh[REG] << 32);
...@@ -101,7 +101,7 @@ void OPPROTO glue(op_store_T2_gpr64_gpr, REG) (void) ...@@ -101,7 +101,7 @@ void OPPROTO glue(op_store_T2_gpr64_gpr, REG) (void)
RETURN(); RETURN();
} }
#endif #endif
#endif /* TARGET_GPR_BITS < 64 */ #endif /* !defined(TARGET_PPC64) */
/* Altivec registers moves */ /* Altivec registers moves */
void OPPROTO glue(op_load_avr_A0_avr, REG) (void) void OPPROTO glue(op_load_avr_A0_avr, REG) (void)
......
...@@ -5822,7 +5822,7 @@ GEN_VR_STX(vxl, 0x07, 0x0F); ...@@ -5822,7 +5822,7 @@ GEN_VR_STX(vxl, 0x07, 0x0F);
/*** SPE extension ***/ /*** SPE extension ***/
/* Register moves */ /* Register moves */
#if TARGET_GPR_BITS < 64 #if !defined(TARGET_PPC64)
GEN32(gen_op_load_gpr64_T0, gen_op_load_gpr64_T0_gpr); GEN32(gen_op_load_gpr64_T0, gen_op_load_gpr64_T0_gpr);
GEN32(gen_op_load_gpr64_T1, gen_op_load_gpr64_T1_gpr); GEN32(gen_op_load_gpr64_T1, gen_op_load_gpr64_T1_gpr);
...@@ -5836,7 +5836,7 @@ GEN32(gen_op_store_T1_gpr64, gen_op_store_T1_gpr64_gpr); ...@@ -5836,7 +5836,7 @@ GEN32(gen_op_store_T1_gpr64, gen_op_store_T1_gpr64_gpr);
GEN32(gen_op_store_T2_gpr64, gen_op_store_T2_gpr64_gpr); GEN32(gen_op_store_T2_gpr64, gen_op_store_T2_gpr64_gpr);
#endif #endif
#else /* TARGET_GPR_BITS < 64 */ #else /* !defined(TARGET_PPC64) */
/* No specific load/store functions: GPRs are already 64 bits */ /* No specific load/store functions: GPRs are already 64 bits */
#define gen_op_load_gpr64_T0 gen_op_load_gpr_T0 #define gen_op_load_gpr64_T0 gen_op_load_gpr_T0
...@@ -5851,7 +5851,7 @@ GEN32(gen_op_store_T2_gpr64, gen_op_store_T2_gpr64_gpr); ...@@ -5851,7 +5851,7 @@ GEN32(gen_op_store_T2_gpr64, gen_op_store_T2_gpr64_gpr);
#define gen_op_store_T2_gpr64 gen_op_store_T2_gpr #define gen_op_store_T2_gpr64 gen_op_store_T2_gpr
#endif #endif
#endif /* TARGET_GPR_BITS < 64 */ #endif /* !defined(TARGET_PPC64) */
#define GEN_SPE(name0, name1, opc2, opc3, inval, type) \ #define GEN_SPE(name0, name1, opc2, opc3, inval, type) \
GEN_HANDLER(name0##_##name1, 0x04, opc2, opc3, inval, type) \ GEN_HANDLER(name0##_##name1, 0x04, opc2, opc3, inval, type) \
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册