aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/unix/sysv
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>1995-10-26 04:17:49 +0000
committerRoland McGrath <roland@gnu.org>1995-10-26 04:17:49 +0000
commitefc755b2825063ab0e0928a5c77caac721192ff1 (patch)
treec1226bf3a221ff0bcd7f0c302434145cd6e80c56 /sysdeps/unix/sysv
parent413349877625cb89ab4e82befe33e3bc64a29579 (diff)
downloadglibc-efc755b2825063ab0e0928a5c77caac721192ff1.zip
glibc-efc755b2825063ab0e0928a5c77caac721192ff1.tar.gz
glibc-efc755b2825063ab0e0928a5c77caac721192ff1.tar.bz2
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.S2
-rw-r--r--sysdeps/unix/sysv/linux/i386/mmap.S2
-rw-r--r--sysdeps/unix/sysv/linux/i386/sbrk.S2
-rw-r--r--sysdeps/unix/sysv/linux/i386/sigaction.c86
-rw-r--r--sysdeps/unix/sysv/linux/i386/socket.S2
-rw-r--r--sysdeps/unix/sysv/linux/i386/syscall.S2
-rw-r--r--sysdeps/unix/sysv/linux/i386/xmknod.S2
-rw-r--r--sysdeps/unix/sysv/linux/i386/xstat.S2
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 2a9a2bc..754ec5e 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 1d1d628..90ac88c 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 e38e88f..31ed27b 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 0000000..6986290
--- /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 b2e6b26..5a7d774 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 52eb48a..b7b44e7 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 10778bd..e075e52 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 58c5f55..b936bb5 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. */