summaryrefslogtreecommitdiffstats
path: root/src/mutex-posix.c
blob: 8d8b88b0531b08d4c638cc3d47283a69521daa73 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/***
  This file is part of libcanberra.

  Copyright 2008 Lennart Poettering

  libcanberra is free software; you can redistribute it and/or modify
  it under the terms of the GNU Lesser General Public License as
  published by the Free Software Foundation, either version 2.1 of the
  License, or (at your option) any later version.

  libcanberra is distributed in the hope that it will be useful, but
  WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  Lesser General Public License for more details.

  You should have received a copy of the GNU Lesser General Public
  License along with libcanberra. If not, see
  <http://www.gnu.org/licenses/>.
***/

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include <pthread.h>
#include <errno.h>

#include "mutex.h"
#include "malloc.h"

struct ca_mutex {
    pthread_mutex_t mutex;
};

ca_mutex* ca_mutex_new(void) {
    ca_mutex *m;

    if (!(m = ca_new(ca_mutex, 1)))
        return NULL;

    if (pthread_mutex_init(&m->mutex, NULL) < 0) {
        ca_free(m);
        return NULL;
    }

    return m;
}

void ca_mutex_free(ca_mutex *m) {
    ca_assert(m);

    ca_assert_se(pthread_mutex_destroy(&m->mutex) == 0);
    ca_free(m);
}

void ca_mutex_lock(ca_mutex *m) {
    ca_assert(m);

    ca_assert_se(pthread_mutex_lock(&m->mutex) == 0);
}

ca_bool_t ca_mutex_try_lock(ca_mutex *m) {
    int r;
    ca_assert(m);

    if ((r = pthread_mutex_trylock(&m->mutex)) != 0) {
        ca_assert(r == EBUSY);
        return FALSE;
    }

    return TRUE;
}

void ca_mutex_unlock(ca_mutex *m) {
    ca_assert(m);

    ca_assert_se(pthread_mutex_unlock(&m->mutex) == 0);
}