提交 94159135 编写于 作者: M Meador Inge 提交者: Aurelien Jarno

target-mips: Enable access to required RDHWR hardware registers

While running in the usermode emulator all of the required*
MIPS32r2 RDHWR hardware registers should be accessible (the
Linux kernel enables access to these same registers).  Note
that these registers are still enabled when the MIPS ISA is
not release 2.  This is OK since the Linux kernel emulates
access to them when they are not available in hardware.

* There is also the ULR register which is only recommended
  for full release 2 compliance.  Incidentally, accessing
  this register in the current implementation works fine
  without flipping its access bit.
Signed-off-by: NMeador Inge <meadori@codesourcery.com>
Signed-off-by: NAurelien Jarno <aurelien@aurel32.net>
上级 58617a79
...@@ -12768,8 +12768,9 @@ void cpu_state_reset(CPUMIPSState *env) ...@@ -12768,8 +12768,9 @@ void cpu_state_reset(CPUMIPSState *env)
#if defined(CONFIG_USER_ONLY) #if defined(CONFIG_USER_ONLY)
env->hflags = MIPS_HFLAG_UM; env->hflags = MIPS_HFLAG_UM;
/* Enable access to the SYNCI_Step register. */ /* Enable access to the CPUNum, SYNCI_Step, CC, and CCRes RDHWR
env->CP0_HWREna |= (1 << 1); hardware registers. */
env->CP0_HWREna |= 0x0000000F;
if (env->CP0_Config1 & (1 << CP0C1_FP)) { if (env->CP0_Config1 & (1 << CP0C1_FP)) {
env->hflags |= MIPS_HFLAG_FPU; env->hflags |= MIPS_HFLAG_FPU;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册