Return to thread.h CVS log | Up to [ELWIX - Embedded LightWeight unIX -] / embedaddon / strongswan / src / libstrongswan / threading / windows |
1.1 misho 1: /* 2: * Copyright (C) 2013 Martin Willi 3: * Copyright (C) 2013 revosec AG 4: * 5: * This program is free software; you can redistribute it and/or modify it 6: * under the terms of the GNU General Public License as published by the 7: * Free Software Foundation; either version 2 of the License, or (at your 8: * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>. 9: * 10: * This program is distributed in the hope that it will be useful, but 11: * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 12: * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 13: * for more details. 14: */ 15: 16: #ifndef WINDOWS_THREAD_H_ 17: #define WINDOWS_THREAD_H_ 18: 19: /* for conditionVariables, Vista */ 20: #define _WIN32_WINNT 0x0600 21: #include <library.h> 22: 23: /** 24: * @defgroup windowsthread windows 25: * @ingroup threading 26: * 27: * @defgroup threadwindows thread 28: * @{ @ingroup windowsthread 29: */ 30: 31: /** 32: * Set active condvar of a thread before waiting in it. 33: * 34: * @param condvar active condition variable, NULL to unset 35: */ 36: void thread_set_active_condvar(CONDITION_VARIABLE *condvar); 37: 38: /** 39: * Set a thread specific value on the current thread. 40: * 41: * @param key unique key specifying the TLS variable 42: * @param value value to set 43: * @return old value for key, if any 44: */ 45: void* thread_tls_put(void *key, void *value); 46: 47: /** 48: * Get a thread specific value from the current thread. 49: * 50: * @param key unique key specifying the TLS variable 51: * @return value for key, if any 52: */ 53: void* thread_tls_get(void *key); 54: 55: /** 56: * Remove a thread specific value from the current thread. 57: * 58: * @param key unique key specifying the TLS variable 59: * @return value for key, if any 60: */ 61: void* thread_tls_remove(void *key); 62: 63: /** 64: * Cleanup function for thread specific value. 65: * 66: * This is called whenever a thread exits to clean up thread specific data. 67: * 68: * This function is actually implemented in thread_value.c. 69: * 70: * @param value value, as passed to thread_tls_put() 71: */ 72: void thread_tls_cleanup(void *value); 73: 74: #endif /** WINDOWS_THREAD_H_ @}*/