X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=ucw%2Fthreads.h;h=3c1f29b799ccf292e44ae38df900d23e5fe67326;hb=0db6e10eac28f38bfc3b325b13ad95107c58ce1e;hp=5644d152ce9b6fe1fb71ce29c5de940a0e2f25da;hpb=e8060fa4647c5c4ccf07efb91a35f65c543dfc4f;p=libucw.git diff --git a/ucw/threads.h b/ucw/threads.h index 5644d152..3c1f29b7 100644 --- a/ucw/threads.h +++ b/ucw/threads.h @@ -1,34 +1,61 @@ /* * The UCW Library -- Threading Helpers * - * (c) 2006 Martin Mares + * (c) 2006--2012 Martin Mares * * This software may be freely distributed and used according to the terms * of the GNU Lesser General Public License. */ -#ifndef _UCW_THREAD_H -#define _UCW_THREAD_H +#ifndef _UCW_THREADS_H +#define _UCW_THREADS_H + +#include /* This structure holds per-thread data */ struct ucwlib_context { - int thread_id; // Thread ID (either kernel tid or a counter) + int _thread_id; // Thread ID (either kernel tid or a counter, use ucwlib_thread_id()) int temp_counter; // Counter for fb-temp.c struct asio_queue *io_queue; // Async I/O queue for fb-direct.c ucw_sighandler_t *signal_handlers; // Signal handlers for sighandler.c + struct main_context *main_context; // Current context for mainloop.c + struct cf_context *cf_context; // Current context for configuration parser + // Resources and transactions: + struct respool *current_respool; // Current resource pool + struct mempool *trans_pool; // Transaction mempool + struct trans *current_trans; // Currently open transaction }; +#ifdef CONFIG_UCW_THREADS + +#ifdef CONFIG_UCW_TLS +extern __thread struct ucwlib_context ucwlib_context; +static inline struct ucwlib_context *ucwlib_thread_context(void) { return &ucwlib_context; } +int ucwlib_thread_id(struct ucwlib_context *c); +#else struct ucwlib_context *ucwlib_thread_context(void); +static inline int ucwlib_thread_id(struct ucwlib_context *c) { return c->_thread_id; } +#endif /* Global lock used for initialization, cleanup and other not so frequently accessed global state */ void ucwlib_lock(void); void ucwlib_unlock(void); -#ifdef CONFIG_UCW_THREADS +extern uns ucwlib_thread_stack_size; + +#else + +/* We have no threads, let's simulate the context and locking */ + +extern struct ucwlib_context default_ucwlib_context; +static inline struct ucwlib_context *ucwlib_thread_context(void) { return &default_ucwlib_context; } + +static inline int ucwlib_thread_id(struct ucwlib_context *c UNUSED) { return 0; } -extern uns default_thread_stack_size; +static inline void ucwlib_lock(void) { } +static inline void ucwlib_unlock(void) { } #endif