mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-24 12:23:32 +01:00
Add tor_cond_init/uninit
This commit is contained in:
parent
e865248156
commit
65016304d2
@ -148,28 +148,23 @@ tor_get_thread_id(void)
|
|||||||
|
|
||||||
/* Conditions. */
|
/* Conditions. */
|
||||||
|
|
||||||
/** Return a newly allocated condition, with nobody waiting on it. */
|
int
|
||||||
tor_cond_t *
|
tor_cond_init(tor_cond_t *cond)
|
||||||
tor_cond_new(void)
|
|
||||||
{
|
{
|
||||||
tor_cond_t *cond = tor_malloc_zero(sizeof(tor_cond_t));
|
memset(cond, 0, sizeof(tor_cond_t));
|
||||||
if (pthread_cond_init(&cond->cond, NULL)) {
|
if (pthread_cond_init(&cond->cond, NULL)) {
|
||||||
tor_free(cond);
|
return -1;
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
return cond;
|
return 0;
|
||||||
}
|
}
|
||||||
/** Release all resources held by <b>cond</b>. */
|
/** Release all resources held by <b>cond</b>. */
|
||||||
void
|
void
|
||||||
tor_cond_free(tor_cond_t *cond)
|
tor_cond_uninit(tor_cond_t *cond)
|
||||||
{
|
{
|
||||||
if (!cond)
|
|
||||||
return;
|
|
||||||
if (pthread_cond_destroy(&cond->cond)) {
|
if (pthread_cond_destroy(&cond->cond)) {
|
||||||
log_warn(LD_GENERAL,"Error freeing condition: %s", strerror(errno));
|
log_warn(LD_GENERAL,"Error freeing condition: %s", strerror(errno));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
tor_free(cond);
|
|
||||||
}
|
}
|
||||||
/** Wait until one of the tor_cond_signal functions is called on <b>cond</b>.
|
/** Wait until one of the tor_cond_signal functions is called on <b>cond</b>.
|
||||||
* All waiters on the condition must wait holding the same <b>mutex</b>.
|
* All waiters on the condition must wait holding the same <b>mutex</b>.
|
||||||
|
@ -24,6 +24,23 @@ tor_mutex_free(tor_mutex_t *m)
|
|||||||
tor_free(m);
|
tor_free(m);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tor_cond_t *
|
||||||
|
tor_cond_new(void)
|
||||||
|
{
|
||||||
|
tor_cond_t *cond = tor_malloc(sizeof(tor_cond_t));
|
||||||
|
if (tor_cond_init(cond)<0)
|
||||||
|
tor_free(cond);
|
||||||
|
return cond;
|
||||||
|
}
|
||||||
|
void
|
||||||
|
tor_cond_free(tor_cond_t *c)
|
||||||
|
{
|
||||||
|
if (!c)
|
||||||
|
return;
|
||||||
|
tor_cond_uninit(c);
|
||||||
|
tor_free(c);
|
||||||
|
}
|
||||||
|
|
||||||
/** Identity of the "main" thread */
|
/** Identity of the "main" thread */
|
||||||
static unsigned long main_thread_id = -1;
|
static unsigned long main_thread_id = -1;
|
||||||
|
|
||||||
|
@ -74,6 +74,8 @@ typedef struct tor_cond_t {
|
|||||||
|
|
||||||
tor_cond_t *tor_cond_new(void);
|
tor_cond_t *tor_cond_new(void);
|
||||||
void tor_cond_free(tor_cond_t *cond);
|
void tor_cond_free(tor_cond_t *cond);
|
||||||
|
int tor_cond_init(tor_cond_t *cond);
|
||||||
|
void tor_cond_uninit(tor_cond_t *cond);
|
||||||
int tor_cond_wait(tor_cond_t *cond, tor_mutex_t *mutex,
|
int tor_cond_wait(tor_cond_t *cond, tor_mutex_t *mutex,
|
||||||
const struct timeval *tv);
|
const struct timeval *tv);
|
||||||
void tor_cond_signal_one(tor_cond_t *cond);
|
void tor_cond_signal_one(tor_cond_t *cond);
|
||||||
|
@ -70,30 +70,25 @@ tor_get_thread_id(void)
|
|||||||
return (unsigned long)GetCurrentThreadId();
|
return (unsigned long)GetCurrentThreadId();
|
||||||
}
|
}
|
||||||
|
|
||||||
tor_cond_t *
|
int
|
||||||
tor_cond_new(void)
|
tor_cond_init(tor_cond_t *cond)
|
||||||
{
|
{
|
||||||
tor_cond_t *cond = tor_malloc(sizeof(tor_cond_t));
|
memset(cond, 0, sizeof(tor_cond_t));
|
||||||
if (InitializeCriticalSectionAndSpinCount(&cond->lock, SPIN_COUNT)==0) {
|
if (InitializeCriticalSectionAndSpinCount(&cond->lock, SPIN_COUNT)==0) {
|
||||||
tor_free(cond);
|
return -1;
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
if ((cond->event = CreateEvent(NULL,TRUE,FALSE,NULL)) == NULL) {
|
if ((cond->event = CreateEvent(NULL,TRUE,FALSE,NULL)) == NULL) {
|
||||||
DeleteCriticalSection(&cond->lock);
|
DeleteCriticalSection(&cond->lock);
|
||||||
tor_free(cond);
|
return -1;
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
cond->n_waiting = cond->n_to_wake = cond->generation = 0;
|
cond->n_waiting = cond->n_to_wake = cond->generation = 0;
|
||||||
return cond;
|
return 0;
|
||||||
}
|
}
|
||||||
void
|
void
|
||||||
tor_cond_free(tor_cond_t *cond)
|
tor_cond_uninit(tor_cond_t *cond)
|
||||||
{
|
{
|
||||||
if (!cond)
|
|
||||||
return;
|
|
||||||
DeleteCriticalSection(&cond->lock);
|
DeleteCriticalSection(&cond->lock);
|
||||||
CloseHandle(cond->event);
|
CloseHandle(cond->event);
|
||||||
mm_free(cond);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
Loading…
Reference in New Issue
Block a user