summaryrefslogtreecommitdiffstats
path: root/mdk-stage1/dietlibc/libpthread/pthread_sys_logging.c
diff options
context:
space:
mode:
authorMystery Man <unknown@mandriva.org>2001-05-14 14:17:54 +0000
committerMystery Man <unknown@mandriva.org>2001-05-14 14:17:54 +0000
commit16984701aa5165b77f229cc318e8025ee8cf81b5 (patch)
tree923ed2780582f751b2be106641be35cf71fedd66 /mdk-stage1/dietlibc/libpthread/pthread_sys_logging.c
parentc5050eb3ba91cf0eab748b773dcbb34b88ae88bc (diff)
downloaddrakx-backup-do-not-use-topic/dietlibc.tar
drakx-backup-do-not-use-topic/dietlibc.tar.gz
drakx-backup-do-not-use-topic/dietlibc.tar.bz2
drakx-backup-do-not-use-topic/dietlibc.tar.xz
drakx-backup-do-not-use-topic/dietlibc.zip
This commit was manufactured by cvs2svn to create branch 'dietlibc'.topic/dietlibc
Diffstat (limited to 'mdk-stage1/dietlibc/libpthread/pthread_sys_logging.c')
-rw-r--r--mdk-stage1/dietlibc/libpthread/pthread_sys_logging.c31
1 files changed, 31 insertions, 0 deletions
diff --git a/mdk-stage1/dietlibc/libpthread/pthread_sys_logging.c b/mdk-stage1/dietlibc/libpthread/pthread_sys_logging.c
new file mode 100644
index 000000000..6070ad219
--- /dev/null
+++ b/mdk-stage1/dietlibc/libpthread/pthread_sys_logging.c
@@ -0,0 +1,31 @@
+#include <unistd.h>
+#include <stdarg.h>
+
+#include <pthread.h>
+#include "thread_internal.h"
+
+static pthread_mutex_t mutex_syslog = PTHREAD_MUTEX_INITIALIZER;
+
+void closelog(void)
+{
+ pthread_cleanup_push((void(*)(void*))pthread_mutex_unlock,&mutex_syslog);
+ pthread_mutex_lock(&mutex_syslog);
+ __libc_closelog();
+ pthread_cleanup_pop(1);
+}
+
+void openlog(const char *ident, int option, int facility)
+{
+ pthread_cleanup_push((void(*)(void*))pthread_mutex_unlock,&mutex_syslog);
+ pthread_mutex_lock(&mutex_syslog);
+ __libc_openlog(ident, option, facility);
+ pthread_cleanup_pop(1);
+}
+
+void vsyslog(int priority, const char *format, va_list arg_ptr)
+{
+ pthread_cleanup_push((void(*)(void*))pthread_mutex_unlock,&mutex_syslog);
+ pthread_mutex_lock(&mutex_syslog);
+ __libc_vsyslog(priority, format, arg_ptr);
+ pthread_cleanup_pop(1);
+}