aboutsummaryrefslogtreecommitdiff
path: root/nptl
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2002-12-08 09:41:40 +0000
committerUlrich Drepper <drepper@redhat.com>2002-12-08 09:41:40 +0000
commit1e50662964de0684256118a2775ac05cf80e4f6f (patch)
treed25ba529835db686bff9783d8c9f4cd9c2831d41 /nptl
parenta3957dd58406620c6b4541bafb412d68723979c8 (diff)
downloadglibc-1e50662964de0684256118a2775ac05cf80e4f6f.zip
glibc-1e50662964de0684256118a2775ac05cf80e4f6f.tar.gz
glibc-1e50662964de0684256118a2775ac05cf80e4f6f.tar.bz2
Update.
* pthreadP.h: Enable pthread_cleanup_{push,pop} optimizations only inside libpthread.
Diffstat (limited to 'nptl')
-rw-r--r--nptl/ChangeLog3
-rw-r--r--nptl/pthreadP.h10
2 files changed, 9 insertions, 4 deletions
diff --git a/nptl/ChangeLog b/nptl/ChangeLog
index b97c512..a1152ea 100644
--- a/nptl/ChangeLog
+++ b/nptl/ChangeLog
@@ -1,5 +1,8 @@
2002-12-08 Ulrich Drepper <drepper@redhat.com>
+ * pthreadP.h: Enable pthread_cleanup_{push,pop} optimizations only
+ inside libpthread.
+
* pt-fcntl.c (__fcntl): Initialize oldtype to avoid warning.
* pthreadP.h: Declare __pthread_enable_asynccancel and
diff --git a/nptl/pthreadP.h b/nptl/pthreadP.h
index c90b782..4fba194 100644
--- a/nptl/pthreadP.h
+++ b/nptl/pthreadP.h
@@ -190,19 +190,21 @@ extern int __pthread_setcanceltype (int type, int *oldtype);
extern int __pthread_enable_asynccancel (void) attribute_hidden;
extern void __pthread_disable_asynccancel (int oldtype) attribute_hidden;
+#ifdef IS_IN_libpthread
/* Special versions which use non-exported functions. */
extern void _GI_pthread_cleanup_push (struct _pthread_cleanup_buffer *buffer,
void (*routine) (void *), void *arg)
attribute_hidden;
-#undef pthread_cleanup_push
-#define pthread_cleanup_push(routine,arg) \
+# undef pthread_cleanup_push
+# define pthread_cleanup_push(routine,arg) \
{ struct _pthread_cleanup_buffer _buffer; \
_GI_pthread_cleanup_push (&_buffer, (routine), (arg));
extern void _GI_pthread_cleanup_pop (struct _pthread_cleanup_buffer *buffer,
int execute) attribute_hidden;
-#undef pthread_cleanup_pop
-#define pthread_cleanup_pop(execute) \
+# undef pthread_cleanup_pop
+# define pthread_cleanup_pop(execute) \
_GI_pthread_cleanup_pop (&_buffer, (execute)); }
+#endif
#endif /* pthreadP.h */