]> git.kernelconcepts.de Git - karo-tx-linux.git/commit
x86/signal: Remove pax argument from restore_sigcontext
authorBrian Gerst <brgerst@gmail.com>
Sat, 4 Apr 2015 12:58:23 +0000 (08:58 -0400)
committerIngo Molnar <mingo@kernel.org>
Mon, 6 Apr 2015 07:06:39 +0000 (09:06 +0200)
commit6a3713f001b3b53587e411ab0d3036ae9b0fb93b
treeb45db33d637a9465388642e04de58daa8892cf82
parentdbe4058a6a44af4ca5d146aebe01b0a1f9b7fd2a
x86/signal: Remove pax argument from restore_sigcontext

The 'pax' argument is unnecesary.  Instead, store the RAX value
directly in regs.

This pattern goes all the way back to 2.1.106pre1, when restore_sigcontext()
was changed to return an error code instead of EAX directly:

  https://git.kernel.org/cgit/linux/kernel/git/history/history.git/diff/arch/i386/kernel/signal.c?id=9a8f8b7ca3f319bd668298d447bdf32730e51174

In 2007 sigaltstack syscall support was added, where the return
value of restore_sigcontext() was changed to carry the memory-copying
failure code.

But instead of putting 'ax' into regs->ax directly, it was carried
in via a pointer and then returned, where the generic syscall return
code copied it to regs->ax.

So there was never any deeper reason for this suboptimal pattern, it
was simply never noticed after being introduced.

Signed-off-by: Brian Gerst <brgerst@gmail.com>
Cc: Andy Lutomirski <luto@amacapital.net>
Cc: Borislav Petkov <bp@alien8.de>
Cc: Denys Vlasenko <dvlasenk@redhat.com>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/1428152303-17154-1-git-send-email-brgerst@gmail.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
arch/x86/ia32/ia32_signal.c
arch/x86/include/asm/sighandling.h
arch/x86/kernel/signal.c