This is the mail archive of the libc-alpha@sources.redhat.com mailing list for the glibc project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[PATCH] NPTL enable Altivec for setjmp/longjmp part 5 of 5


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);
+

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]