mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
powerpc: Emulate non privileged DSCR read and write
commit 73d2fb758e
upstream.
POWER8 allows read and write of the DSCR in userspace. We added
kernel emulation so applications could always use the instructions
regardless of the CPU type.
Unfortunately there are two SPRs for the DSCR and we only added
emulation for the privileged one. Add code to match the non
privileged one.
A simple test was created to verify the fix:
http://ozlabs.org/~anton/junkcode/user_dscr_test.c
Without the patch we get a SIGILL and it passes with the patch.
Signed-off-by: Anton Blanchard <anton@samba.org>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
306110aead
commit
169a6c2f1b
2 changed files with 12 additions and 2 deletions
|
@ -45,6 +45,10 @@
|
|||
#define PPC_INST_MFSPR_DSCR_MASK 0xfc1fffff
|
||||
#define PPC_INST_MTSPR_DSCR 0x7c1103a6
|
||||
#define PPC_INST_MTSPR_DSCR_MASK 0xfc1fffff
|
||||
#define PPC_INST_MFSPR_DSCR_USER 0x7c0302a6
|
||||
#define PPC_INST_MFSPR_DSCR_USER_MASK 0xfc1fffff
|
||||
#define PPC_INST_MTSPR_DSCR_USER 0x7c0303a6
|
||||
#define PPC_INST_MTSPR_DSCR_USER_MASK 0xfc1fffff
|
||||
#define PPC_INST_SLBFEE 0x7c0007a7
|
||||
|
||||
#define PPC_INST_STRING 0x7c00042a
|
||||
|
|
|
@ -960,7 +960,10 @@ static int emulate_instruction(struct pt_regs *regs)
|
|||
|
||||
#ifdef CONFIG_PPC64
|
||||
/* Emulate the mfspr rD, DSCR. */
|
||||
if (((instword & PPC_INST_MFSPR_DSCR_MASK) == PPC_INST_MFSPR_DSCR) &&
|
||||
if ((((instword & PPC_INST_MFSPR_DSCR_USER_MASK) ==
|
||||
PPC_INST_MFSPR_DSCR_USER) ||
|
||||
((instword & PPC_INST_MFSPR_DSCR_MASK) ==
|
||||
PPC_INST_MFSPR_DSCR)) &&
|
||||
cpu_has_feature(CPU_FTR_DSCR)) {
|
||||
PPC_WARN_EMULATED(mfdscr, regs);
|
||||
rd = (instword >> 21) & 0x1f;
|
||||
|
@ -968,7 +971,10 @@ static int emulate_instruction(struct pt_regs *regs)
|
|||
return 0;
|
||||
}
|
||||
/* Emulate the mtspr DSCR, rD. */
|
||||
if (((instword & PPC_INST_MTSPR_DSCR_MASK) == PPC_INST_MTSPR_DSCR) &&
|
||||
if ((((instword & PPC_INST_MTSPR_DSCR_USER_MASK) ==
|
||||
PPC_INST_MTSPR_DSCR_USER) ||
|
||||
((instword & PPC_INST_MTSPR_DSCR_MASK) ==
|
||||
PPC_INST_MTSPR_DSCR)) &&
|
||||
cpu_has_feature(CPU_FTR_DSCR)) {
|
||||
PPC_WARN_EMULATED(mtdscr, regs);
|
||||
rd = (instword >> 21) & 0x1f;
|
||||
|
|
Loading…
Reference in a new issue