fix static linking dependency bloat with cancellation
authorRich Felker <dalias@aerifal.cx>
Wed, 3 Aug 2011 23:45:21 +0000 (19:45 -0400)
committerRich Felker <dalias@aerifal.cx>
Wed, 3 Aug 2011 23:45:21 +0000 (19:45 -0400)
previously, pthread_cleanup_push/pop were pulling in all of
pthread_create due to dependency on the __pthread_unwind_next
function. this was not needed, as cancellation cleanup handlers can
never be called unless pthread_exit or pthread_cancel is reachable.

src/thread/cancellation.c
src/thread/cancellation3.c [deleted file]
src/thread/i386/cancellation2.s
src/thread/i386/cancellation3.s [deleted file]
src/thread/pthread_create.c

index 4976fed..6dfee53 100644 (file)
@@ -3,10 +3,22 @@
 #ifdef __pthread_register_cancel
 #undef __pthread_register_cancel
 #undef __pthread_unregister_cancel
+#undef __pthread_unwind_next
 #define __pthread_register_cancel __pthread_register_cancel_3
 #define __pthread_unregister_cancel __pthread_unregister_cancel_3
+#define __pthread_unwind_next __pthread_unwind_next_3
 #endif
 
+static void dummy(struct __ptcb *cb)
+{
+}
+weak_alias(dummy, __pthread_do_unwind);
+
+void __pthread_unwind_next(struct __ptcb *cb)
+{
+       __pthread_do_unwind(cb);
+}
+
 void __pthread_register_cancel(struct __ptcb *cb)
 {
        struct pthread *self = pthread_self();
diff --git a/src/thread/cancellation3.c b/src/thread/cancellation3.c
deleted file mode 100644 (file)
index e69de29..0000000
index 4e4438b..beeffb9 100644 (file)
@@ -14,3 +14,11 @@ __pthread_unregister_cancel:
        call __pthread_unregister_cancel_3
        popl %eax
        ret
+
+.global __pthread_unwind_next
+.type   __pthread_unwind_next,@function
+__pthread_unwind_next:
+       pushl %eax
+       call __pthread_unwind_next_3
+       popl %eax
+       ret
diff --git a/src/thread/i386/cancellation3.s b/src/thread/i386/cancellation3.s
deleted file mode 100644 (file)
index 8834022..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-.text
-.global __pthread_unwind_next
-.type   __pthread_unwind_next,@function
-__pthread_unwind_next:
-       pushl %eax
-       call __pthread_unwind_next_3
-       popl %eax
-       ret
index adef510..a6afd1e 100644 (file)
@@ -8,12 +8,7 @@ weak_alias(dummy_0, __synccall_lock);
 weak_alias(dummy_0, __synccall_unlock);
 weak_alias(dummy_0, __pthread_tsd_run_dtors);
 
-#ifdef __pthread_unwind_next
-#undef __pthread_unwind_next
-#define __pthread_unwind_next __pthread_unwind_next_3
-#endif
-
-void __pthread_unwind_next(struct __ptcb *cb)
+void __pthread_do_unwind(struct __ptcb *cb)
 {
        pthread_t self = pthread_self();
        int n;