diff options
author | Tobias Brunner <tobias@strongswan.org> | 2012-07-12 09:34:56 +0200 |
---|---|---|
committer | Tobias Brunner <tobias@strongswan.org> | 2012-07-12 09:43:27 +0200 |
commit | 2b19dd350212c7be2904afe40751da177e3c3fc9 (patch) | |
tree | a78aaded4acf3a5f92da6da509174568418730e5 /src/libstrongswan/threading | |
parent | bbe5b50567e6a507ca063c41540ddfec8684c271 (diff) | |
download | strongswan-2b19dd350212c7be2904afe40751da177e3c3fc9.tar.bz2 strongswan-2b19dd350212c7be2904afe40751da177e3c3fc9.tar.xz |
Properly cleanup thread-local values for the threads destroying thread_value_t objects
Diffstat (limited to 'src/libstrongswan/threading')
-rw-r--r-- | src/libstrongswan/threading/thread_value.c | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/src/libstrongswan/threading/thread_value.c b/src/libstrongswan/threading/thread_value.c index 3fa70acb2..190b7434f 100644 --- a/src/libstrongswan/threading/thread_value.c +++ b/src/libstrongswan/threading/thread_value.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2009 Tobias Brunner + * Copyright (C) 2009-2012 Tobias Brunner * Hochschule fuer Technik Rapperswil * * This program is free software; you can redistribute it and/or modify it @@ -33,6 +33,11 @@ struct private_thread_value_t { */ pthread_key_t key; + /** + * Destructor to cleanup the value of the thread destroying this object + */ + thread_cleanup_t destructor; + }; METHOD(thread_value_t, set, void, @@ -50,11 +55,22 @@ METHOD(thread_value_t, get, void*, METHOD(thread_value_t, destroy, void, private_thread_value_t *this) { + void *val; + + /* the destructor is not called automatically for the thread calling + * pthread_key_delete() */ + if (this->destructor) + { + val = pthread_getspecific(this->key); + if (val) + { + this->destructor(val); + } + } pthread_key_delete(this->key); free(this); } - /** * Described in header. */ @@ -68,6 +84,7 @@ thread_value_t *thread_value_create(thread_cleanup_t destructor) .get = _get, .destroy = _destroy, }, + .destructor = destructor, ); pthread_key_create(&this->key, destructor); |