summaryrefslogtreecommitdiff
path: root/src/libaudcore/tinylock.h.in
blob: 873af1b1290f50e692b6b9a9464b314e56ed2cb9 (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
/*
 * tinylock.h
 * Copyright 2013 John Lindgren
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain the above copyright notice,
 *    this list of conditions, and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright notice,
 *    this list of conditions, and the following disclaimer in the documentation
 *    provided with the distribution.
 *
 * This software is provided "as is" and without any warranty, express or
 * implied. In no event shall the authors be liable for any damages arising from
 * the use of this software.
 */

#ifndef LIBAUDCORE_TINYLOCK_H
#define LIBAUDCORE_TINYLOCK_H

#if @VALGRIND_FRIENDLY@ /* VALGRIND_FRIENDLY */

#include <pthread.h>

typedef pthread_mutex_t TinyLock;
typedef pthread_rwlock_t TinyRWLock;

#define tiny_lock pthread_mutex_lock
#define tiny_unlock pthread_mutex_unlock
#define tiny_lock_read pthread_rwlock_rdlock
#define tiny_unlock_read pthread_rwlock_unlock
#define tiny_lock_write pthread_rwlock_wrlock
#define tiny_unlock_write pthread_rwlock_unlock

#else /* ! VALGRIND_FRIENDLY */

/* TinyLock is an extremely low-overhead lock object (in terms of speed and
 * memory usage).  It makes no guarantees of fair scheduling, however. */

typedef char TinyLock;

void tiny_lock (TinyLock * lock);
void tiny_unlock (TinyLock * lock);

typedef unsigned short TinyRWLock;

void tiny_lock_read (TinyRWLock * lock);
void tiny_unlock_read (TinyRWLock * lock);
void tiny_lock_write (TinyRWLock * lock);
void tiny_unlock_write (TinyRWLock * lock);

#endif /* ! VALGRIND_FRIENDLY */

#endif /* LIBAUDCORE_TINYLOCK_H */