blob: 7509d4409ade7ace9ec125ada33c8a7b73dd5284 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
/* Wrapper for setting errno.
*
* Copyright (C) 2000-2006 Erik Andersen <andersen@uclibc.org>
*
* Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball.
*/
/* This routine is jumped to by all the syscall handlers, to stash
* an error number into errno. */
/* This version uses a lot of magic and relies heavily on x86
* calling convention ... The advantage is that this is the same
* size as the previous __syscall_error() but all the .S functions
* need just one instruction.
*
* Local .S files have to set %eax to the negative errno value
* and then jump to this function. The neglected return to caller
* and return value of -1 is taken care of here so we don't have to
* worry about it in the .S functions.
*
* We have to stash the errno from %eax in a local stack var because
* __set_errno will prob call a function thus clobbering %eax on us.
*/
#include <errno.h>
#include <features.h>
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);
return -1;
}
|