From 444eacba82f675d4657ad55da67b355536be90ab Mon Sep 17 00:00:00 2001 From: Samuel Thibault Date: Thu, 22 Sep 2016 02:43:39 +0200 Subject: hurd: Fix stack pointer corruption in syscall Thanks Justus Winter for the report. * sysdeps/mach/i386/syscall.S (syscall): Push back syscall number. --- sysdeps/mach/i386/syscall.S | 3 +++ 1 file changed, 3 insertions(+) (limited to 'sysdeps/mach/i386') diff --git a/sysdeps/mach/i386/syscall.S b/sysdeps/mach/i386/syscall.S index adb7716948..643cddc9ba 100644 --- a/sysdeps/mach/i386/syscall.S +++ b/sysdeps/mach/i386/syscall.S @@ -22,5 +22,8 @@ ENTRY (syscall) popl %eax /* Pop syscall number into %eax. */ pushl %ecx /* Push back return address. */ .byte 0x9a, 0, 0, 0, 0, 7, 0 /* lcall $7, $0 -- gas bug */ + popl %ecx /* Pop return address into %ecx. */ + pushl $0 /* Push back dumb syscall number. */ + pushl %ecx /* Push back return address. */ ret END (syscall) -- cgit v1.2.3