summaryrefslogtreecommitdiff
path: root/drivers/uio
diff options
context:
space:
mode:
authorPaul Mackerras <paulus@samba.org>2013-06-14 20:07:41 +1000
committerBen Hutchings <ben@decadent.org.uk>2013-06-19 02:17:02 +0100
commite4f37de094d8c0a55af0fe63d7f715457b2de3e6 (patch)
tree7916aacd2ee03cf10a3ba06a20ed7cd479b37530 /drivers/uio
parent08647d0f99db39f73f37e00ebafc24ff3d3f4948 (diff)
downloadlwn-e4f37de094d8c0a55af0fe63d7f715457b2de3e6.tar.gz
lwn-e4f37de094d8c0a55af0fe63d7f715457b2de3e6.zip
powerpc: Fix emulation of illegal instructions on PowerNV platform
commit bf593907f7236e95698a76b7c7a2bbf8b1165327 upstream. Normally, the kernel emulates a few instructions that are unimplemented on some processors (e.g. the old dcba instruction), or privileged (e.g. mfpvr). The emulation of unimplemented instructions is currently not working on the PowerNV platform. The reason is that on these machines, unimplemented and illegal instructions cause a hypervisor emulation assist interrupt, rather than a program interrupt as on older CPUs. Our vector for the emulation assist interrupt just calls program_check_exception() directly, without setting the bit in SRR1 that indicates an illegal instruction interrupt. This fixes it by making the emulation assist interrupt set that bit before calling program_check_interrupt(). With this, old programs that use no-longer implemented instructions such as dcba now work again. Signed-off-by: Paul Mackerras <paulus@samba.org> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org> [bwh: Backported to 3.2: adjust context] Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
Diffstat (limited to 'drivers/uio')
0 files changed, 0 insertions, 0 deletions