mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-16 00:34:20 +08:00
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>
This commit is contained in:
parent
2bfc96a127
commit
7fe977dab3
@ -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;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user