2 * Copyright (c) 2005 Christophe Varoqui
13 #include "log_pthread.h"
19 pthread_mutex_t logq_lock;
20 pthread_mutex_t logev_lock;
21 pthread_cond_t logev_cond;
25 void log_safe (int prio, const char * fmt, va_list ap)
27 if (log_thr == (pthread_t)0) {
28 syslog(prio, fmt, ap);
32 pthread_mutex_lock(&logq_lock);
33 log_enqueue(prio, fmt, ap);
34 pthread_mutex_unlock(&logq_lock);
36 pthread_mutex_lock(&logev_lock);
37 pthread_cond_signal(&logev_cond);
38 pthread_mutex_unlock(&logev_lock);
41 void log_thread_flush (void)
46 pthread_mutex_lock(&logq_lock);
47 empty = log_dequeue(la->buff);
48 pthread_mutex_unlock(&logq_lock);
54 static void flush_logqueue (void)
59 pthread_mutex_lock(&logq_lock);
60 empty = log_dequeue(la->buff);
61 pthread_mutex_unlock(&logq_lock);
67 static void * log_thread (void * et)
71 pthread_mutex_lock(&logev_lock);
73 pthread_mutex_unlock(&logev_lock);
75 mlockall(MCL_CURRENT | MCL_FUTURE);
76 logdbg(stderr,"enter log_thread\n");
79 pthread_mutex_lock(&logev_lock);
80 pthread_cond_wait(&logev_cond, &logev_lock);
81 running = logq_running;
82 pthread_mutex_unlock(&logev_lock);
90 void log_thread_start (pthread_attr_t *attr)
92 logdbg(stderr,"enter log_thread_start\n");
94 pthread_mutex_init(&logq_lock, NULL);
95 pthread_mutex_init(&logev_lock, NULL);
96 pthread_cond_init(&logev_cond, NULL);
98 if (log_init("multipathd", 0)) {
99 fprintf(stderr,"can't initialize log buffer\n");
102 if (pthread_create(&log_thr, attr, log_thread, NULL)) {
103 fprintf(stderr,"can't start log thread\n");
110 void log_thread_stop (void)
112 logdbg(stderr,"enter log_thread_stop\n");
114 pthread_mutex_lock(&logev_lock);
116 pthread_cond_signal(&logev_cond);
117 pthread_mutex_unlock(&logev_lock);
119 pthread_mutex_lock(&logq_lock);
120 pthread_cancel(log_thr);
121 pthread_mutex_unlock(&logq_lock);
122 pthread_join(log_thr, NULL);
123 log_thr = (pthread_t)0;
127 pthread_mutex_destroy(&logq_lock);
128 pthread_mutex_destroy(&logev_lock);
129 pthread_cond_destroy(&logev_cond);