svn commit: trunk/uClibc/libc: misc/pthread sysdeps/linux/common/bits

andersen at uclibc.org andersen at uclibc.org
Sat Dec 9 01:32:15 UTC 2006


Author: andersen
Date: 2006-12-08 17:32:13 -0800 (Fri, 08 Dec 2006)
New Revision: 16825

Log:
silence a lot of warnings and fix a few genuine bugs while I'm at it.


Added:
   trunk/uClibc/libc/misc/pthread/unlock.c

Modified:
   trunk/uClibc/libc/misc/pthread/Makefile.in
   trunk/uClibc/libc/misc/pthread/weaks.c
   trunk/uClibc/libc/sysdeps/linux/common/bits/uClibc_mutex.h
   trunk/uClibc/libc/sysdeps/linux/common/bits/uClibc_pthread.h


Changeset:
Modified: trunk/uClibc/libc/misc/pthread/Makefile.in
===================================================================
--- trunk/uClibc/libc/misc/pthread/Makefile.in	2006-12-08 22:53:40 UTC (rev 16824)
+++ trunk/uClibc/libc/misc/pthread/Makefile.in	2006-12-09 01:32:13 UTC (rev 16825)
@@ -8,7 +8,8 @@
 MISC_PTHREAD_DIR := $(top_srcdir)libc/misc/pthread
 MISC_PTHREAD_OUT := $(top_builddir)libc/misc/pthread
 
-libc-$(UCLIBC_HAS_THREADS) += $(MISC_PTHREAD_OUT)/weaks.o
+libc-$(UCLIBC_HAS_THREADS) += $(MISC_PTHREAD_OUT)/unlock.o
+libc-static-$(UCLIBC_HAS_THREADS) += $(MISC_PTHREAD_OUT)/weaks.o
 
 objclean-y += misc_pthread_objclean
 

Added: trunk/uClibc/libc/misc/pthread/unlock.c
===================================================================
--- trunk/uClibc/libc/misc/pthread/unlock.c	2006-12-08 22:53:40 UTC (rev 16824)
+++ trunk/uClibc/libc/misc/pthread/unlock.c	2006-12-09 01:32:13 UTC (rev 16825)
@@ -0,0 +1,26 @@
+/* The weak pthread functions for Linux.
+   Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 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
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <pthread.h>
+
+void attribute_hidden __uclibc_mutex_unlock (void *arg)
+{
+	pthread_mutex_t *__mutex = (pthread_mutex_t *)arg;
+	pthread_mutex_unlock(__mutex);
+}

Modified: trunk/uClibc/libc/misc/pthread/weaks.c
===================================================================
--- trunk/uClibc/libc/misc/pthread/weaks.c	2006-12-08 22:53:40 UTC (rev 16824)
+++ trunk/uClibc/libc/misc/pthread/weaks.c	2006-12-09 01:32:13 UTC (rev 16825)
@@ -28,7 +28,6 @@
  * if it gets linked in.
  */
 
-static int __pthread_return_0 (void);
 static int __pthread_return_0 (void) { return 0; }
 static void __pthread_return_void (void) { return; }
 

Modified: trunk/uClibc/libc/sysdeps/linux/common/bits/uClibc_mutex.h
===================================================================
--- trunk/uClibc/libc/sysdeps/linux/common/bits/uClibc_mutex.h	2006-12-08 22:53:40 UTC (rev 16824)
+++ trunk/uClibc/libc/sysdeps/linux/common/bits/uClibc_mutex.h	2006-12-09 01:32:13 UTC (rev 16825)
@@ -36,7 +36,7 @@
 		struct _pthread_cleanup_buffer __infunc_pthread_cleanup_buffer;				\
 		if (C) {										\
 			_pthread_cleanup_push_defer(&__infunc_pthread_cleanup_buffer,			\
-										__pthread_mutex_unlock,	\
+										__uclibc_mutex_unlock,	\
 										&(M));			\
 			__pthread_mutex_lock(&(M));							\
 		}											\

Modified: trunk/uClibc/libc/sysdeps/linux/common/bits/uClibc_pthread.h
===================================================================
--- trunk/uClibc/libc/sysdeps/linux/common/bits/uClibc_pthread.h	2006-12-08 22:53:40 UTC (rev 16824)
+++ trunk/uClibc/libc/sysdeps/linux/common/bits/uClibc_pthread.h	2006-12-09 01:32:13 UTC (rev 16825)
@@ -28,11 +28,21 @@
 #endif
 
 #if defined _LIBC && (defined IS_IN_libc || defined NOT_IN_libc)
-extern int __pthread_mutex_init (pthread_mutex_t *__restrict __mutex,
-		__const pthread_mutexattr_t *__restrict __mutex_attr) attribute_hidden;
-extern int __pthread_mutex_trylock (pthread_mutex_t *__mutex) attribute_hidden;
-extern int __pthread_mutex_lock (pthread_mutex_t *__mutex) attribute_hidden;
-extern int __pthread_mutex_unlock (pthread_mutex_t *__mutex) attribute_hidden;
+/* Threading functions internal to uClibc.  Make these thread functions
+ * weak so that we can elide them from single-threaded processes.  */
+extern int weak_function __pthread_mutex_init (pthread_mutex_t *__mutex,
+		__const pthread_mutexattr_t *__mutex_attr);
+extern int weak_function __pthread_mutex_destroy (pthread_mutex_t *__mutex);
+extern int weak_function __pthread_mutex_lock (pthread_mutex_t *__mutex);
+extern int weak_function __pthread_mutex_unlock (pthread_mutex_t *__mutex);
+extern void __uclibc_mutex_unlock (void *) attribute_hidden;
+extern int weak_function __pthread_mutex_trylock (pthread_mutex_t *__mutex);
+extern void weak_function _pthread_cleanup_push_defer (
+		struct _pthread_cleanup_buffer *__buffer,
+		void (*__routine) (void *), void *__arg);
+extern void weak_function _pthread_cleanup_pop_restore (
+		struct _pthread_cleanup_buffer *__buffer,
+		int __execute);
 #endif
 
 #endif




More information about the uClibc-cvs mailing list