This is the mail archive of the
libc-alpha@sources.redhat.com
mailing list for the glibc project.
[PATCH] NPTL enable Altivec for setjmp/longjmp part 5 of 5
- From: Steve Munroe <sjmunroe at us dot ibm dot com>
- To: libc-alpha at sources dot redhat dot com, Tom Gall <tom_gall at vnet dot ibm dot com>, Dwayne McConnell <dgm69 at us dot ibm dot com>, Segher Boessenkoof <segher at kernel dot crashing dot org>
- Date: Mon, 19 Jan 2004 15:21:48 -0600
- Subject: [PATCH] NPTL enable Altivec for setjmp/longjmp part 5 of 5
- Organization: IBM LTC
- Reply-to: sjmunroe at vnet dot ibm dot com
For NPTL I also split the __pthread_cleanup_upto function out of
pt-longjmp into a pt-cleanup.c file. This allows for ppc specific
versions of pt-longjmp.c in sysdeps/unix/sysv/linux/powerpc/powerpc32/
and powerpc64/. Different source is required for 32-/64-bit because the
version ranges differ.
2004-01-16 Steven Munroe <sjmunroe@us.ibm.com>
* Makefile(libpthread-routines): Add pt-cleanup
* pt-longjmp.c: Removed.
* pt-cleanup.c: Copied __pthread_cleanup_upto to here. New file.
* sysdeps/generic/pt-longjmp.c: Copied longjmp to here. New file.
* sysdeps/unix/sysv/linux/powerpc/powerpc32/Versions: New file.
Add longjmp, siglongjmp to GLIBC_2.3.4.
* sysdeps/unix/sysv/linux/powerpc/powerpc32/pt-longjmp.c: New File.
* sysdeps/unix/sysv/linux/powerpc/powerpc64/Versions: New file.
Add longjmp, siglongjmp to GLIBC_2.3.4.
* sysdeps/unix/sysv/linux/powerpc/powerpc64/pt-longjmp.c: New File.
diff -urN libc23-cvstip-20040116/nptl/Makefile libc23/nptl/Makefile
--- libc23-cvstip-20040116/nptl/Makefile 2004-01-08 12:20:58.000000000 -0600
+++ libc23/nptl/Makefile 2004-01-17 19:47:05.000000000 -0600
@@ -99,7 +99,7 @@
sem_wait sem_trywait sem_timedwait sem_post \
cleanup cleanup_defer cleanup_compat \
cleanup_defer_compat unwind \
- pt-longjmp \
+ pt-longjmp pt-cleanup\
cancellation \
lowlevellock \
pt-vfork \
diff -urN libc23-cvstip-20040116/nptl/pt-cleanup.c libc23/nptl/pt-cleanup.c
--- libc23-cvstip-20040116/nptl/pt-cleanup.c Wed Dec 31 17:00:00 1969
+++ libc23/nptl/pt-cleanup.c Sat Jan 17 19:33:32 2004
@@ -0,0 +1,64 @@
+/* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+ Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 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
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, write to the Free
+ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+ 02111-1307 USA. */
+
+#include <setjmp.h>
+#include <stdlib.h>
+#include "pthreadP.h"
+#include "jmpbuf-unwind.h"
+
+void
+__pthread_cleanup_upto (__jmp_buf target, char *targetframe)
+{
+ struct pthread *self = THREAD_SELF;
+ struct _pthread_cleanup_buffer *cbuf;
+
+ /* Adjust all pointers used in comparisons, so that top of thread's
+ stack is at the top of address space. Without that, things break
+ if stack is allocated above the main stack. */
+ uintptr_t adj = (uintptr_t) self->stackblock + self->stackblock_size;
+ uintptr_t targetframe_adj = (uintptr_t) targetframe - adj;
+
+ for (cbuf = THREAD_GETMEM (self, cleanup);
+ cbuf != NULL && _JMPBUF_UNWINDS_ADJ (target, cbuf, adj);
+ cbuf = cbuf->__prev)
+ {
+#if _STACK_GROWS_DOWN
+ if ((uintptr_t) cbuf - adj <= targetframe_adj)
+ {
+ cbuf = NULL;
+ break;
+ }
+#elif _STACK_GROWS_UP
+ if ((uintptr_t) cbuf - adj >= targetframe_adj)
+ {
+ cbuf = NULL;
+ break;
+ }
+#else
+# error "Define either _STACK_GROWS_DOWN or _STACK_GROWS_UP"
+#endif
+
+ /* Call the cleanup code. */
+ cbuf->__routine (cbuf->__arg);
+ }
+
+ THREAD_SETMEM (self, cleanup, cbuf);
+}
+hidden_def (__pthread_cleanup_upto)
+
diff -urN libc23-cvstip-20040116/nptl/pt-longjmp.c libc23/nptl/pt-longjmp.c
--- libc23-cvstip-20040116/nptl/pt-longjmp.c Thu Dec 18 19:31:08 2003
+++ libc23/nptl/pt-longjmp.c Wed Dec 31 17:00:00 1969
@@ -1,71 +0,0 @@
-/* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
- This file is part of the GNU C Library.
- Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
-
- The GNU C Library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Lesser General Public
- License as published by the Free Software Foundation; either
- version 2.1 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
- Lesser General Public License for more details.
-
- You should have received a copy of the GNU Lesser General Public
- License along with the GNU C Library; if not, write to the Free
- Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
- 02111-1307 USA. */
-
-#include <setjmp.h>
-#include <stdlib.h>
-#include "pthreadP.h"
-#include "jmpbuf-unwind.h"
-
-void
-__pthread_cleanup_upto (__jmp_buf target, char *targetframe)
-{
- struct pthread *self = THREAD_SELF;
- struct _pthread_cleanup_buffer *cbuf;
-
- /* Adjust all pointers used in comparisons, so that top of thread's
- stack is at the top of address space. Without that, things break
- if stack is allocated above the main stack. */
- uintptr_t adj = (uintptr_t) self->stackblock + self->stackblock_size;
- uintptr_t targetframe_adj = (uintptr_t) targetframe - adj;
-
- for (cbuf = THREAD_GETMEM (self, cleanup);
- cbuf != NULL && _JMPBUF_UNWINDS_ADJ (target, cbuf, adj);
- cbuf = cbuf->__prev)
- {
-#if _STACK_GROWS_DOWN
- if ((uintptr_t) cbuf - adj <= targetframe_adj)
- {
- cbuf = NULL;
- break;
- }
-#elif _STACK_GROWS_UP
- if ((uintptr_t) cbuf - adj >= targetframe_adj)
- {
- cbuf = NULL;
- break;
- }
-#else
-# error "Define either _STACK_GROWS_DOWN or _STACK_GROWS_UP"
-#endif
-
- /* Call the cleanup code. */
- cbuf->__routine (cbuf->__arg);
- }
-
- THREAD_SETMEM (self, cleanup, cbuf);
-}
-hidden_def (__pthread_cleanup_upto)
-
-
-void
-longjmp (jmp_buf env, int val)
-{
- __libc_longjmp (env, val);
-}
-weak_alias (longjmp, siglongjmp)
diff -urN libc23-cvstip-20040116/nptl/sysdeps/generic/pt-longjmp.c libc23/nptl/sysdeps/generic/pt-longjmp.c
--- libc23-cvstip-20040116/nptl/sysdeps/generic/pt-longjmp.c Wed Dec 31 17:00:00 1969
+++ libc23/nptl/sysdeps/generic/pt-longjmp.c Sat Jan 17 19:33:43 2004
@@ -0,0 +1,29 @@
+/* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+ Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 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
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, write to the Free
+ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+ 02111-1307 USA. */
+
+#include <setjmp.h>
+#include <stdlib.h>
+#include "pthreadP.h"
+
+void
+longjmp (jmp_buf env, int val)
+{
+ __libc_longjmp (env, val);
+}
+weak_alias (longjmp, siglongjmp)
diff -urN libc23-cvstip-20040116/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc32/Versions libc23/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc32/Versions
--- libc23-cvstip-20040116/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc32/Versions Wed Dec 31 17:00:00 1969
+++ libc23/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc32/Versions Sat Jan 17 19:33:43 2004
@@ -0,0 +1,5 @@
+libpthread {
+ GLIBC_2.3.4 {
+ longjmp; siglongjmp;
+ }
+}
diff -urN libc23-cvstip-20040116/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc32/pt-longjmp.c libc23/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc32/pt-longjmp.c
--- libc23-cvstip-20040116/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc32/pt-longjmp.c Wed Dec 31 17:00:00 1969
+++ libc23/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc32/pt-longjmp.c Sat Jan 17 19:33:43 2004
@@ -0,0 +1,75 @@
+/* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+ Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 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
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, write to the Free
+ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+ 02111-1307 USA. */
+
+#include <setjmp.h>
+#include <stdlib.h>
+#include "pthreadP.h"
+#include <shlib-compat.h>
+#if defined SHARED && SHLIB_COMPAT (libc, GLIBC_2_0, GLIBC_2_3_4)
+#include <stddef.h>
+#include <novmxsetjmp.h>
+#include <signal.h>
+
+
+/* Set the signal mask to the one specified in ENV, and jump
+ to the position specified in ENV, causing the setjmp
+ call there to return VAL, or 1 if VAL is 0. */
+void
+__novmx__libc_siglongjmp (sigjmp_buf env, int val)
+{
+ /* Perform any cleanups needed by the frames being unwound. */
+ _longjmp_unwind (env, val);
+
+ if (env[0].__mask_was_saved)
+ /* Restore the saved signal mask. */
+ (void) __sigprocmask (SIG_SETMASK, &env[0].__saved_mask,
+ (sigset_t *) NULL);
+
+ /* Call the machine-dependent function to restore machine state. */
+ __novmx__longjmp (env[0].__jmpbuf, val ?: 1);
+}
+
+strong_alias (__novmx__libc_siglongjmp, __novmx__libc_longjmp)
+libc_hidden_def (__novmx__libc_longjmp)
+weak_alias (__novmx__libc_siglongjmp, __novmx_longjmp)
+weak_alias (__novmx__libc_siglongjmp, __novmxlongjmp)
+weak_alias (__novmx__libc_siglongjmp, __novmxsiglongjmp)
+
+symbol_version (__novmx__libc_longjmp,__libc_longjmp,GLIBC_2.1);
+symbol_version (__novmx__libc_siglongjmp,__libc_siglongjmp,GLIBC_2.1);
+symbol_version (__novmx_longjmp,_longjmp,GLIBC_2.1);
+symbol_version (__novmxlongjmp,longjmp,GLIBC_2.1);
+symbol_version (__novmxsiglongjmp,siglongjmp,GLIBC_2.1);
+#endif /* defined SHARED && SHLIB_COMPAT (libc, GLIBC_2_0, GLIBC_2_3_4)) */
+
+void
+__vmx_longjmp (jmp_buf env, int val)
+{
+ __libc_longjmp (env, val);
+}
+
+void
+__vmx_siglongjmp (jmp_buf env, int val)
+{
+ __libc_siglongjmp (env, val);
+}
+
+versioned_symbol (libc, __vmx_longjmp, longjmp, GLIBC_2_3_4);
+versioned_symbol (libc, __vmx_siglongjmp, siglongjmp, GLIBC_2_3_4);
+
diff -urN libc23-cvstip-20040116/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc64/Versions libc23/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc64/Versions
--- libc23-cvstip-20040116/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc64/Versions 2003-03-25 14:11:21.000000000 -0600
+++ libc23/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc64/Versions 2004-01-17 19:33:43.000000000 -0600
@@ -1,3 +1,8 @@
+libpthread {
+ GLIBC_2.3.4 {
+ longjmp; siglongjmp;
+ }
+}
librt {
GLIBC_2.3.3 {
# Changed timer_t.
diff -urN libc23-cvstip-20040116/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc64/pt-longjmp.c libc23/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc64/pt-longjmp.c
--- libc23-cvstip-20040116/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc64/pt-longjmp.c Wed Dec 31 17:00:00 1969
+++ libc23/nptl/sysdeps/unix/sysv/linux/powerpc/powerpc64/pt-longjmp.c Sat Jan 17 19:33:43 2004
@@ -0,0 +1,62 @@
+/* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+ Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 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
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, write to the Free
+ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+ 02111-1307 USA. */
+
+#include <setjmp.h>
+#include <stdlib.h>
+#include "pthreadP.h"
+#include <shlib-compat.h>
+#if defined SHARED && SHLIB_COMPAT (libpthread, GLIBC_2_3, GLIBC_2_3_4)
+#include <novmxsetjmp.h>
+
+/* These functions are not declared anywhere since they shouldn't be
+ used at another place but here. */
+extern void __novmx__libc_siglongjmp (sigjmp_buf env, int val)
+ __attribute__ ((noreturn));
+extern void __novmx__libc_longjmp (sigjmp_buf env, int val)
+ __attribute__ ((noreturn));
+
+
+void __novmxsiglongjmp (sigjmp_buf env, int val)
+{
+ __novmx__libc_siglongjmp (env, val);
+}
+
+void __novmxlongjmp (jmp_buf env, int val)
+{
+ __novmx__libc_longjmp (env, val);
+}
+
+symbol_version (__novmxlongjmp,longjmp,GLIBC_2.3);
+symbol_version (__novmxsiglongjmp,siglongjmp,GLIBC_2.3);
+#endif
+
+void
+__vmx_longjmp (jmp_buf env, int val)
+{
+ __libc_longjmp (env, val);
+}
+void
+
+__vmx_siglongjmp (jmp_buf env, int val)
+{
+ __libc_siglongjmp (env, val);
+}
+versioned_symbol (libc, __vmx_longjmp, longjmp, GLIBC_2_3_4);
+versioned_symbol (libc, __vmx_siglongjmp, siglongjmp, GLIBC_2_3_4);
+