diff options
author | Jan Beulich <JBeulich@novell.com> | 2010-09-02 14:01:58 +0100 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2010-09-03 08:16:02 +0200 |
commit | 7fe977dab356fbd7e86aa10bf83891761107c57c (patch) | |
tree | 7a9e5618fc4a1f04cca7bbd9e337847fb5cc38be /arch/x86/kernel/sys_i386_32.c | |
parent | 2bfc96a127bc1cc94d26bfaa40159966064f9c8c (diff) | |
download | kernel_samsung_tuna-7fe977dab356fbd7e86aa10bf83891761107c57c.zip kernel_samsung_tuna-7fe977dab356fbd7e86aa10bf83891761107c57c.tar.gz kernel_samsung_tuna-7fe977dab356fbd7e86aa10bf83891761107c57c.tar.bz2 |
i386: Make kernel_execve() suitable for stack unwinding
The explicit saving and restoring of %ebx was confusing stack
unwind data consumers, and it is plain unnecessary to do this
within the asm(), since that was only introduced for PIC user
mode consumers of the original _syscall3() macro this was
derived from.
Signed-off-by: Jan Beulich <jbeulich@novell.com>
Cc: Arnd Bergmann <arnd@arndb.de>
LKML-Reference: <4C7FBC660200007800013F95@vpn.id2.novell.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/sys_i386_32.c')
-rw-r--r-- | arch/x86/kernel/sys_i386_32.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/arch/x86/kernel/sys_i386_32.c b/arch/x86/kernel/sys_i386_32.c index d5e0662..0b0cb5f 100644 --- a/arch/x86/kernel/sys_i386_32.c +++ b/arch/x86/kernel/sys_i386_32.c @@ -33,8 +33,8 @@ int kernel_execve(const char *filename, const char *const envp[]) { long __res; - asm volatile ("push %%ebx ; movl %2,%%ebx ; int $0x80 ; pop %%ebx" + asm volatile ("int $0x80" : "=a" (__res) - : "0" (__NR_execve), "ri" (filename), "c" (argv), "d" (envp) : "memory"); + : "0" (__NR_execve), "b" (filename), "c" (argv), "d" (envp) : "memory"); return __res; } |