summaryrefslogtreecommitdiffstats
path: root/fs/cifs/smb1ops.c
diff options
context:
space:
mode:
authorSteffen Rumler <steffen.rumler.ext@nsn.com>2012-06-06 16:37:17 +0200
committerPaul Mackerras <paulus@samba.org>2012-06-08 19:59:08 +1000
commit3c75296562f43e6fbc6cddd3de948a7b3e4e9bcf (patch)
tree9840ae6c30254bd80b628c776a78d856720a9b94 /fs/cifs/smb1ops.c
parent860aed25a1f0936d4852ab936252b47cd1e630f1 (diff)
downloadlinux-3c75296562f43e6fbc6cddd3de948a7b3e4e9bcf.tar.gz
linux-3c75296562f43e6fbc6cddd3de948a7b3e4e9bcf.tar.xz
linux-3c75296562f43e6fbc6cddd3de948a7b3e4e9bcf.zip
powerpc: Fix kernel panic during kernel module load
This fixes a problem which can causes kernel oopses while loading a kernel module. According to the PowerPC EABI specification, GPR r11 is assigned the dedicated function to point to the previous stack frame. In the powerpc-specific kernel module loader, do_plt_call() (in arch/powerpc/kernel/module_32.c), GPR r11 is also used to generate trampoline code. This combination crashes the kernel, in the case where the compiler chooses to use a helper function for saving GPRs on entry, and the module loader has placed the .init.text section far away from the .text section, meaning that it has to generate a trampoline for functions in the .init.text section to call the GPR save helper. Because the trampoline trashes r11, references to the stack frame using r11 can cause an oops. The fix just uses GPR r12 instead of GPR r11 for generating the trampoline code. According to the statements from Freescale, this is safe from an EABI perspective. I've tested the fix for kernel 2.6.33 on MPC8541. Cc: stable@vger.kernel.org Signed-off-by: Steffen Rumler <steffen.rumler.ext@nsn.com> [paulus@samba.org: reworded the description] Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'fs/cifs/smb1ops.c')
0 files changed, 0 insertions, 0 deletions