[git commit] i386: store errno value before using __set_errno()
Mike Frysinger
vapier at gentoo.org
Fri Jul 3 19:24:05 UTC 2009
commit: http://git.uclibc.org/uClibc/commit/?id=38265c7af552c1874b75c76818a082d2841c717b
branch: http://git.uclibc.org/uClibc/commit/?id=refs/heads/master
The __syscall_error() function stores the errno value in the edx register
before invoking the __set_errno() macro. When using the pthread library
this macro calls thread_self() to determine the errno location, which might
clobber the edx register. The errno value must be stored in a "real"
variable so the compiler can take care of saving/restoring it if necessary.
Signed-off-by: Ingo van Lil <inguin at gmx.de>
Signed-off-by: Mike Frysinger <vapier at gentoo.org>
---
libc/sysdeps/linux/i386/__syscall_error.c | 7 +++----
1 files changed, 3 insertions(+), 4 deletions(-)
diff --git a/libc/sysdeps/linux/i386/__syscall_error.c b/libc/sysdeps/linux/i386/__syscall_error.c
index 7509d44..36946bc 100644
--- a/libc/sysdeps/linux/i386/__syscall_error.c
+++ b/libc/sysdeps/linux/i386/__syscall_error.c
@@ -28,9 +28,8 @@
int __syscall_error(void) attribute_hidden;
int __syscall_error(void)
{
- register int edx __asm__ ("%edx");
- __asm__ ("mov %eax, %edx\n\t"
- "negl %edx");
- __set_errno (edx);
+ register int eax __asm__ ("%eax");
+ int _errno = -eax;
+ __set_errno (_errno);
return -1;
}
--
1.6.3.3
More information about the uClibc-cvs
mailing list