mirror of
https://github.com/jedisct1/libsodium.git
synced 2024-12-31 22:42:57 -07:00
Tolerate sodium_crit_leave() to be called on an unlocked mutex
This commit is contained in:
parent
5d484e6cb2
commit
bfcaab49f3
@ -1,4 +1,5 @@
|
|||||||
|
|
||||||
|
#include <assert.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
@ -36,6 +37,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
static volatile int initialized;
|
static volatile int initialized;
|
||||||
|
static volatile int locked;
|
||||||
|
|
||||||
int
|
int
|
||||||
sodium_init(void)
|
sodium_init(void)
|
||||||
@ -98,6 +100,8 @@ sodium_crit_enter(void)
|
|||||||
return -1; /* LCOV_EXCL_LINE */
|
return -1; /* LCOV_EXCL_LINE */
|
||||||
}
|
}
|
||||||
EnterCriticalSection(&_sodium_lock);
|
EnterCriticalSection(&_sodium_lock);
|
||||||
|
assert(locked == 0);
|
||||||
|
locked = 1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -105,6 +109,13 @@ sodium_crit_enter(void)
|
|||||||
int
|
int
|
||||||
sodium_crit_leave(void)
|
sodium_crit_leave(void)
|
||||||
{
|
{
|
||||||
|
if (locked == 0) {
|
||||||
|
# ifdef EPERM
|
||||||
|
errno = EPERM;
|
||||||
|
# endif
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
locked = 0;
|
||||||
LeaveCriticalSection(&_sodium_lock);
|
LeaveCriticalSection(&_sodium_lock);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -117,12 +128,28 @@ static pthread_mutex_t _sodium_lock = PTHREAD_MUTEX_INITIALIZER;
|
|||||||
int
|
int
|
||||||
sodium_crit_enter(void)
|
sodium_crit_enter(void)
|
||||||
{
|
{
|
||||||
return pthread_mutex_lock(&_sodium_lock);
|
int ret;
|
||||||
|
|
||||||
|
if ((ret = pthread_mutex_lock(&_sodium_lock)) == 0) {
|
||||||
|
assert(locked == 0);
|
||||||
|
locked = 1;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
sodium_crit_leave(void)
|
sodium_crit_leave(void)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (locked == 0) {
|
||||||
|
# ifdef EPERM
|
||||||
|
errno = EPERM;
|
||||||
|
# endif
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
locked = 0;
|
||||||
|
|
||||||
return pthread_mutex_unlock(&_sodium_lock);
|
return pthread_mutex_unlock(&_sodium_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -178,7 +205,7 @@ sodium_misuse(void)
|
|||||||
{
|
{
|
||||||
void (*handler)(void);
|
void (*handler)(void);
|
||||||
|
|
||||||
sodium_crit_leave();
|
(void) sodium_crit_leave();
|
||||||
if (sodium_crit_enter() == 0) {
|
if (sodium_crit_enter() == 0) {
|
||||||
handler = _misuse_handler;
|
handler = _misuse_handler;
|
||||||
if (handler != NULL) {
|
if (handler != NULL) {
|
||||||
|
Loading…
Reference in New Issue
Block a user