diff options
author | Roland McGrath <roland@gnu.org> | 1995-10-26 04:17:49 +0000 |
---|---|---|
committer | Roland McGrath <roland@gnu.org> | 1995-10-26 04:17:49 +0000 |
commit | efc755b2825063ab0e0928a5c77caac721192ff1 (patch) | |
tree | c1226bf3a221ff0bcd7f0c302434145cd6e80c56 /sysdeps/unix/sysv | |
parent | 413349877625cb89ab4e82befe33e3bc64a29579 (diff) | |
download | glibc-efc755b2825063ab0e0928a5c77caac721192ff1.tar glibc-efc755b2825063ab0e0928a5c77caac721192ff1.tar.gz glibc-efc755b2825063ab0e0928a5c77caac721192ff1.tar.bz2 glibc-efc755b2825063ab0e0928a5c77caac721192ff1.zip |
Thu Oct 26 00:11:13 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu>
* sysdeps/unix/sysv/linux/i386/sigaction.c: New file.
* sysdeps/unix/sysv/linux/i386/xstat.S: Don't use JUMPTARGET macro
on syscall_error. For PIC, it is a local label;
for non-PIC, JUMPTARGET expands to the unadorned name anyway.
* sysdeps/unix/sysv/linux/i386/xmknod.S: Likewise.
* sysdeps/unix/sysv/linux/i386/syscall.S: Likewise.
* sysdeps/unix/sysv/linux/i386/socket.S: Likewise.
* sysdeps/unix/sysv/linux/i386/sbrk.S: Likewise.
* sysdeps/unix/sysv/linux/i386/mmap.S: Likewise.
* sysdeps/unix/sysv/linux/i386/brk.S: Likewise.
Diffstat (limited to 'sysdeps/unix/sysv')
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/brk.S | 2 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/mmap.S | 2 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/sbrk.S | 2 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/sigaction.c | 86 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/socket.S | 2 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/syscall.S | 2 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/xmknod.S | 2 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/xstat.S | 2 |
8 files changed, 93 insertions, 7 deletions
diff --git a/sysdeps/unix/sysv/linux/i386/brk.S b/sysdeps/unix/sysv/linux/i386/brk.S index 2a9a2bcd24..754ec5ef09 100644 --- a/sysdeps/unix/sysv/linux/i386/brk.S +++ b/sysdeps/unix/sysv/linux/i386/brk.S @@ -42,7 +42,7 @@ ENTRY (__brk) movl %edx, %ebx cmpl 4(%esp), %eax - jne JUMPTARGET(syscall_error) + jne syscall_error #ifdef PIC /* Standard PIC nonsense to store into `__curbrk' through the GOT. */ diff --git a/sysdeps/unix/sysv/linux/i386/mmap.S b/sysdeps/unix/sysv/linux/i386/mmap.S index 1d1d628ad5..90ac88c46f 100644 --- a/sysdeps/unix/sysv/linux/i386/mmap.S +++ b/sysdeps/unix/sysv/linux/i386/mmap.S @@ -38,7 +38,7 @@ ENTRY (__mmap) /* %eax is < 0 if there was an error. */ testl %eax, %eax - jl JUMPTARGET(syscall_error) + jl syscall_error /* Successful; return the syscall's value. */ ret diff --git a/sysdeps/unix/sysv/linux/i386/sbrk.S b/sysdeps/unix/sysv/linux/i386/sbrk.S index e38e88f64d..31ed27b9fc 100644 --- a/sysdeps/unix/sysv/linux/i386/sbrk.S +++ b/sysdeps/unix/sysv/linux/i386/sbrk.S @@ -77,6 +77,6 @@ ENTRY (__sbrk) .align 16 .L3: movl %edx, %ebx - jmp JUMPTARGET(syscall_error) + jmp syscall_error weak_alias (__sbrk, sbrk) diff --git a/sysdeps/unix/sysv/linux/i386/sigaction.c b/sysdeps/unix/sysv/linux/i386/sigaction.c new file mode 100644 index 0000000000..6986290da5 --- /dev/null +++ b/sysdeps/unix/sysv/linux/i386/sigaction.c @@ -0,0 +1,86 @@ +/* POSIX.1 `sigaction' call for Linux/i386. +Copyright (C) 1991, 1995 Free Software Foundation, Inc. +This file is part of the GNU C Library. + +The GNU C Library is free software; you can redistribute it and/or +modify it under the terms of the GNU Library General Public License as +published by the Free Software Foundation; either version 2 of the +License, or (at your option) any later version. + +The GNU C Library is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +Library General Public License for more details. + +You should have received a copy of the GNU Library General Public +License along with the GNU C Library; see the file COPYING.LIB. If +not, write to the Free Software Foundation, Inc., 675 Mass Ave, +Cambridge, MA 02139, USA. */ + +#include <sysdep.h> +#include <errno.h> +#include <stddef.h> +#include <signal.h> + + +/* If ACT is not NULL, change the action for SIG to *ACT. + If OACT is not NULL, put the old action for SIG in *OACT. */ +int +__sigaction (int sig, const struct sigaction *act, struct sigaction *oact) +{ + struct sigaction newact; + int result; + + if (new) + { + newact = *new; + new = &newact; + new->sa_restorer = ((new->sa_flags & SA_NOMASK) + ? &&restore_nomask : &&restore); + } + + asm volatile ("pushl %%ebx\n" + "movl %1, %%ebx\n" + "int $0x80\n" + "popl %%ebx" + : "=a" (result) + : "0" (SYS_ify (sigaction)), "g" (sig), "c" (new), "d" (old)); + + if (result < 0) + { + errno = -result; + return -1; + } + return 0; + + restore: + asm ( +#ifdef PIC + " pushl %ebx\n" + " call 0f\n" + "0: popl %ebx\n" + " addl $_GLOBAL_OFFSET_TABLE_+[.-0b],%ebx\n" + " addl $8, %%esp\n" + " call __sigsetmask@PLT\n" + " addl $8, %%esp\n" + " popl %ebx\n" +#else + " addl $4, %%esp\n" + " call __sigsetmask\n" + " addl $4, %%esp\n" +#endif + "popl %eax\n" + "popl %ecx\n" + "popl %edx\n" + "popf\n" + "ret"); + restore_nomask: + asm ("addl $4, %esp\n" + "popl %eax\n" + "popl %ecx\n" + "popl %edx\n" + "popf\n" + "ret"); +} + +weak_alias (__sigaction, sigaction) diff --git a/sysdeps/unix/sysv/linux/i386/socket.S b/sysdeps/unix/sysv/linux/i386/socket.S index b2e6b2603f..5a7d774175 100644 --- a/sysdeps/unix/sysv/linux/i386/socket.S +++ b/sysdeps/unix/sysv/linux/i386/socket.S @@ -53,7 +53,7 @@ ENTRY (P(__,socket)) /* %eax is < 0 if there was an error. */ testl %eax, %eax - jl JUMPTARGET(syscall_error) + jl syscall_error /* Successful; return the syscall's value. */ ret diff --git a/sysdeps/unix/sysv/linux/i386/syscall.S b/sysdeps/unix/sysv/linux/i386/syscall.S index 52eb48a9ae..b7b44e76da 100644 --- a/sysdeps/unix/sysv/linux/i386/syscall.S +++ b/sysdeps/unix/sysv/linux/i386/syscall.S @@ -27,5 +27,5 @@ ENTRY (syscall) int $0x80 /* Do the system call. */ POPARGS_5 /* Restore register contents. */ testl %eax, %eax /* Check %eax for error. */ - jl JUMPTARGET(syscall_error) /* Jump to error handler if negative. */ + jl syscall_error /* Jump to error handler if negative. */ ret /* Return to caller. */ diff --git a/sysdeps/unix/sysv/linux/i386/xmknod.S b/sysdeps/unix/sysv/linux/i386/xmknod.S index 10778bdceb..e075e52105 100644 --- a/sysdeps/unix/sysv/linux/i386/xmknod.S +++ b/sysdeps/unix/sysv/linux/i386/xmknod.S @@ -41,7 +41,7 @@ ENTRY (__xmknod) jmp *%ecx /* Return success. */ .L2: pushl %ecx - jmp JUMPTARGET(syscall_error) + jmp syscall_error /* Yes, then branch to error handling. */ /* For compatibility with Linux libc. */ diff --git a/sysdeps/unix/sysv/linux/i386/xstat.S b/sysdeps/unix/sysv/linux/i386/xstat.S index 58c5f558c4..b936bb5b69 100644 --- a/sysdeps/unix/sysv/linux/i386/xstat.S +++ b/sysdeps/unix/sysv/linux/i386/xstat.S @@ -41,7 +41,7 @@ ENTRY (__xstat) jmp *%ecx /* Return success. */ .L2: pushl %ecx - jmp JUMPTARGET(syscall_error) + jmp syscall_error /* Yes, then branch to error handling. */ /* For compatibility with Linux libc. */ |