aboutsummaryrefslogtreecommitdiffstats
path: root/src/libstrongswan/utils/utils.c
diff options
context:
space:
mode:
authorMartin Willi <martin@revosec.ch>2013-06-11 15:51:50 +0200
committerMartin Willi <martin@revosec.ch>2013-06-11 15:54:27 +0200
commitd024a4652c6a791318e3b17b27006678315a7449 (patch)
tree56769e5b57f1b0d7ca12fedf03dd9cd017f0717a /src/libstrongswan/utils/utils.c
parent37a60cad3cfbf9ce98b6c76564f419fe884a1d71 (diff)
parent3568abe7be1efdd8d95b6711a552fefc8089fff8 (diff)
downloadstrongswan-d024a4652c6a791318e3b17b27006678315a7449.tar.bz2
strongswan-d024a4652c6a791318e3b17b27006678315a7449.tar.xz
Merge branch 'unique-sas'
Makes IKE_SA unique ID and CHILD_SA reqid counters atomic.
Diffstat (limited to 'src/libstrongswan/utils/utils.c')
-rw-r--r--src/libstrongswan/utils/utils.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/libstrongswan/utils/utils.c b/src/libstrongswan/utils/utils.c
index aa59f4a4d..30084cd81 100644
--- a/src/libstrongswan/utils/utils.c
+++ b/src/libstrongswan/utils/utils.c
@@ -466,11 +466,15 @@ static pthread_mutex_t ref_mutex = PTHREAD_MUTEX_INITIALIZER;
/**
* Increase refcount
*/
-void ref_get(refcount_t *ref)
+refcount_t ref_get(refcount_t *ref)
{
+ refcount_t current;
+
pthread_mutex_lock(&ref_mutex);
- (*ref)++;
+ current = ++(*ref);
pthread_mutex_unlock(&ref_mutex);
+
+ return current;
}
/**