about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog10
-rw-r--r--signal/signal.h2
-rw-r--r--sysdeps/i386/backtrace.c2
-rw-r--r--sysdeps/unix/sysv/linux/alpha/syscalls.list1
-rw-r--r--sysdeps/unix/sysv/linux/sigstack.c61
-rw-r--r--sysdeps/unix/sysv/linux/syscalls.list3
6 files changed, 76 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 2b901c02e3..96a9bdaeca 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,13 @@
+1998-06-18 21:45  Ulrich Drepper  <drepper@cygnus.com>
+
+	* signal/signal.h: Add prototype for __sigaltstack.
+	* sysdeps/unix/sysv/linux/syscalls.list: Add __sigaltstack name.
+	Remove sigstack entry.
+	* sysdeps/unix/sysv/linux/alpha/syscalls.list: Add sigstack here.
+	* sysdeps/unix/sysv/linux/sigstack.c: New file.
+
+	* sysdeps/i386/backtrace.c: Add casts.
+
 1998-06-18 19:49  Ulrich Drepper  <drepper@cygnus.com>
 
 	* intl/dcgettext.c: use complete type name.
diff --git a/signal/signal.h b/signal/signal.h
index b42d897f8b..aa51593b67 100644
--- a/signal/signal.h
+++ b/signal/signal.h
@@ -328,6 +328,8 @@ extern int sigstack __P ((__const struct sigstack *__ss,
 
 /* Alternate signal handler stack interface.
    This interface should always be preferred over `sigstack'.  */
+extern int __sigaltstack __P ((__const struct sigaltstack *__ss,
+			       struct sigaltstack *__oss));
 extern int sigaltstack __P ((__const struct sigaltstack *__ss,
 			     struct sigaltstack *__oss));
 
diff --git a/sysdeps/i386/backtrace.c b/sysdeps/i386/backtrace.c
index 5e84205b04..38635988f4 100644
--- a/sysdeps/i386/backtrace.c
+++ b/sysdeps/i386/backtrace.c
@@ -55,7 +55,7 @@ __backtrace (array, size)
   current = (struct layout *) ebp;
   while (cnt < size)
     {
-      if (current < esp || current > __libc_stack_end)
+      if ((void *) current < esp || (void *) current > __libc_stack_end)
 	/* This means the address is out of range.  Note that for the
 	   toplevel we see a frame pointer with value NULL which clearly is
 	   out of range.  */
diff --git a/sysdeps/unix/sysv/linux/alpha/syscalls.list b/sysdeps/unix/sysv/linux/alpha/syscalls.list
index 0b38038d46..ff73a6dc9f 100644
--- a/sysdeps/unix/sysv/linux/alpha/syscalls.list
+++ b/sysdeps/unix/sysv/linux/alpha/syscalls.list
@@ -16,6 +16,7 @@ semget		-	semget		3	__semget	semget
 semctl		-	semctl		4	__semctl	semctl
 
 osf_sigprocmask	-	osf_sigprocmask	2	__osf_sigprocmask
+sigstack	-	sigstack	2	sigstack
 
 getpeername	-	getpeername	3	__getpeername	getpeername
 getpriority	-	getpriority	2	__getpriority	getpriority
diff --git a/sysdeps/unix/sysv/linux/sigstack.c b/sysdeps/unix/sysv/linux/sigstack.c
new file mode 100644
index 0000000000..bca7dc634e
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/sigstack.c
@@ -0,0 +1,61 @@
+/* Emulate sigstack function using sigalstack.
+   Copyright (C) 1998 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+   Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
+
+   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., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <signal.h>
+
+
+int
+sigstack (ss, oss)
+     const struct sigstack *ss;
+     struct sigstack *oss;
+{
+  stack_t sas;
+  stack_t *sasp = NULL;
+  stack_t osas;
+  stack_t *osasp = oss == NULL ? NULL : &osas;
+  int result;
+
+  if (ss != NULL)
+    {
+      /* We have to convert the information.  */
+      sas.ss_sp = ss->ss_sp;
+      sas.ss_flags = ss->ss_onstack ? SS_ONSTACK : 0;
+
+      /* For the size of the stack we have no value we can pass to the
+	 kernel.  This is why this function should not be used.  We simply
+	 assume that all the memory down to address zero (in case the stack
+	 grows down) is available.  */
+      sas.ss_size = ss->ss_sp - NULL;
+
+      sasp = &sas;
+    }
+
+  /* Call the kernel.  */
+  result = __sigaltstack (sasp, osasp);
+
+  /* Convert the result, if wanted and possible.  */
+  if (result == 0 && oss != NULL)
+    {
+      oss->ss_sp = osas.ss_sp;
+      oss->ss_onstack = (osas.ss_flags & SS_ONSTACK) != 0;
+    }
+
+  return result;
+}
diff --git a/sysdeps/unix/sysv/linux/syscalls.list b/sysdeps/unix/sysv/linux/syscalls.list
index 739e29c536..e80fd84568 100644
--- a/sysdeps/unix/sysv/linux/syscalls.list
+++ b/sysdeps/unix/sysv/linux/syscalls.list
@@ -72,8 +72,7 @@ setfsuid	EXTRA	setfsuid	1	setfsuid
 setpgid		-	setpgid		2	__setpgid	setpgid
 setresgid	EXTRA	setresgid	3	setresgid
 setresuid	EXTRA	setresuid	3	setresuid
-sigaltstack	-	sigaltstack	2	sigaltstack
-sigstack	-	sigstack	2	sigstack
+sigaltstack	-	sigaltstack	2	__sigaltstack	sigaltstack
 sys_fstat	fxstat	fstat		2	__syscall_fstat
 sys_lstat	lxstat	lstat		2	__syscall_lstat
 sys_mknod	xmknod	mknod		3	__syscall_mknod