summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2002-12-06 11:31:06 +0000
committerUlrich Drepper <drepper@redhat.com>2002-12-06 11:31:06 +0000
commitd5ddad4ff48cc7887281259dacf5ac455d5a9dd8 (patch)
treeca4b14386bf22dcc9e9f486ac3af7c184179c590
parentfde89ad0091e492bd2d99d9d4925fbd62a7dc643 (diff)
downloadglibc-d5ddad4ff48cc7887281259dacf5ac455d5a9dd8.tar
glibc-d5ddad4ff48cc7887281259dacf5ac455d5a9dd8.tar.gz
glibc-d5ddad4ff48cc7887281259dacf5ac455d5a9dd8.tar.bz2
glibc-d5ddad4ff48cc7887281259dacf5ac455d5a9dd8.zip
(log_cleanup): New function. (openlog): Use log_cleanup instead of __libc_mutex_unlock. (closelog): Likewise.
-rw-r--r--misc/syslog.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/misc/syslog.c b/misc/syslog.c
index 5b3bca2679..c7d92974e9 100644
--- a/misc/syslog.c
+++ b/misc/syslog.c
@@ -329,14 +329,19 @@ openlog_internal(const char *ident, int logstat, int logfac)
}
}
+
+static void
+log_cleanup (void *arg)
+{
+ __libc_lock_unlock (*(__libc_lock_t *) arg);
+}
+
void
openlog (const char *ident, int logstat, int logfac)
{
#ifdef _LIBC_REENTRANT
/* Protect against multiple users. */
- __libc_cleanup_region_start (1,
- (void (*) __P ((void *))) __libc_mutex_unlock,
- &syslog_lock);
+ __libc_cleanup_region_start (1, log_cleanup, &syslog_lock);
__libc_lock_lock (syslog_lock);
#endif
@@ -370,9 +375,7 @@ closelog ()
{
#ifdef _LIBC_REENTRANT
/* Protect against multiple users. */
- __libc_cleanup_region_start (1,
- (void (*) __P ((void *))) __libc_mutex_unlock,
- &syslog_lock);
+ __libc_cleanup_region_start (1, log_cleanup, &syslog_lock);
__libc_lock_lock (syslog_lock);
#endif