diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2013-11-05 06:33:22 +0100 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2013-11-06 04:13:53 +0100 |
commit | 0c4888ef1d8a8b82c29075ce7e257ff795af15c7 (patch) | |
tree | 22f37dca43e49a79236b1279511778a1e8d12c61 /arch/powerpc/kernel/vio.c | |
parent | powerpc/powernv: Reserve the correct PE number (diff) | |
download | linux-0c4888ef1d8a8b82c29075ce7e257ff795af15c7.tar.xz linux-0c4888ef1d8a8b82c29075ce7e257ff795af15c7.zip |
powerpc: Fix fatal SLB miss when restoring PPR
When restoring the PPR value, we incorrectly access the thread structure
at a time where MSR:RI is clear, which means we cannot recover from nested
faults. However the thread structure isn't covered by the "bolted" SLB
entries and thus accessing can fault.
This fixes it by splitting the code so that the PPR value is loaded into
a GPR before MSR:RI is cleared.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/kernel/vio.c')
0 files changed, 0 insertions, 0 deletions