further debloat cancellation handlers
authorRich Felker <dalias@aerifal.cx>
Wed, 3 Aug 2011 23:57:46 +0000 (19:57 -0400)
committerRich Felker <dalias@aerifal.cx>
Wed, 3 Aug 2011 23:57:46 +0000 (19:57 -0400)
cleanup push and pop are also no-ops if pthread_exit is not reachable.
this can make a big difference for library code which needs to protect
itself against cancellation, but which is unlikely to actually be used
in programs with threads/cancellation.

src/thread/cancellation.c
src/thread/cancellation2.c [deleted file]
src/thread/i386/cancellation.s [new file with mode: 0644]
src/thread/i386/cancellation2.s [deleted file]
src/thread/pthread_create.c

index 6dfee53971328100eeca643a975f6fe58ea93a48..b02cdfb093cc528413cc79f1384f19418335b0d6 100644 (file)
@@ -1,18 +1,11 @@
 #include "pthread_impl.h"
 
-#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);
+weak_alias(dummy, __pthread_do_register);
+weak_alias(dummy, __pthread_do_unregister);
 
 void __pthread_unwind_next(struct __ptcb *cb)
 {
@@ -21,13 +14,10 @@ void __pthread_unwind_next(struct __ptcb *cb)
 
 void __pthread_register_cancel(struct __ptcb *cb)
 {
-       struct pthread *self = pthread_self();
-       cb->__next = self->cancelbuf;
-       self->cancelbuf = cb;
+       __pthread_do_register(cb);
 }
 
 void __pthread_unregister_cancel(struct __ptcb *cb)
 {
-       struct pthread *self = __pthread_self();
-       self->cancelbuf = self->cancelbuf->__next;
+       __pthread_do_unregister(cb);
 }
diff --git a/src/thread/cancellation2.c b/src/thread/cancellation2.c
deleted file mode 100644 (file)
index e69de29..0000000
diff --git a/src/thread/i386/cancellation.s b/src/thread/i386/cancellation.s
new file mode 100644 (file)
index 0000000..75dc609
--- /dev/null
@@ -0,0 +1,34 @@
+.text
+.global __pthread_register_cancel
+.type   __pthread_register_cancel,@function
+__pthread_register_cancel:
+       pushl %eax
+       call __pthread_do_register
+       popl %eax
+       ret
+
+.global __pthread_unregister_cancel
+.type   __pthread_unregister_cancel,@function
+__pthread_unregister_cancel:
+       pushl %eax
+       call __pthread_do_unregister
+       popl %eax
+       ret
+
+.global __pthread_unwind_next
+.type   __pthread_unwind_next,@function
+__pthread_unwind_next:
+       pushl %eax
+       call __pthread_do_unwind
+       popl %eax
+__pthread_do_unwind:
+__pthread_do_register:
+__pthread_do_unregister:
+       ret
+
+.weak __pthread_do_unwind
+.weak __pthread_do_register
+.weak __pthread_do_unregister
+.type __pthread_do_unwind,@function
+.type __pthread_do_register,@function
+.type __pthread_do_unregister,@function
diff --git a/src/thread/i386/cancellation2.s b/src/thread/i386/cancellation2.s
deleted file mode 100644 (file)
index beeffb9..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-.text
-.global __pthread_register_cancel
-.type   __pthread_register_cancel,@function
-__pthread_register_cancel:
-       pushl %eax
-       call __pthread_register_cancel_3
-       popl %eax
-       ret
-
-.global __pthread_unregister_cancel
-.type   __pthread_unregister_cancel,@function
-__pthread_unregister_cancel:
-       pushl %eax
-       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
index 0e955911fcc959cdb389739d545a0d2bb48b4f8b..7be58b99ebe695ce60259ba8b8379d0a0efb3907 100644 (file)
@@ -39,6 +39,19 @@ void __pthread_do_unwind(struct __ptcb *cb)
        __syscall(SYS_exit, 0);
 }
 
+void __pthread_do_register(struct __ptcb *cb)
+{
+       struct pthread *self = pthread_self();
+       cb->__next = self->cancelbuf;
+       self->cancelbuf = cb;
+}
+
+void __pthread_do_unregister(struct __ptcb *cb)
+{
+       struct pthread *self = __pthread_self();
+       self->cancelbuf = self->cancelbuf->__next;
+}
+
 static int start(void *p)
 {
        struct pthread *self = p;