summary refs log tree commit diff
path: root/sysdeps/unix/sysv/linux/i386
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/linux/i386
parent413349877625cb89ab4e82befe33e3bc64a29579 (diff)
downloadglibc-efc755b2825063ab0e0928a5c77caac721192ff1.tar.gz
glibc-efc755b2825063ab0e0928a5c77caac721192ff1.tar.xz
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/linux/i386')
-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 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.  */