Skip to content
This repository has been archived by the owner on Feb 11, 2021. It is now read-only.

Latest commit

 

History

History
129 lines (110 loc) · 3.04 KB

SDL_sysmutex.c

File metadata and controls

129 lines (110 loc) · 3.04 KB
 
1
2
/*
SDL - Simple DirectMedia Layer
Feb 1, 2006
Feb 1, 2006
3
Copyright (C) 1997-2006 Sam Lantinga
4
5
This library is free software; you can redistribute it and/or
Feb 1, 2006
Feb 1, 2006
6
modify it under the terms of the GNU Lesser General Public
7
License as published by the Free Software Foundation; either
Feb 1, 2006
Feb 1, 2006
8
version 2.1 of the License, or (at your option) any later version.
9
10
11
12
This library 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
Feb 1, 2006
Feb 1, 2006
13
Lesser General Public License for more details.
Feb 1, 2006
Feb 1, 2006
15
16
17
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18
19
20
21
Sam Lantinga
slouken@libsdl.org
*/
Feb 21, 2006
Feb 21, 2006
22
#include "SDL_config.h"
23
24
25
26
27
28
29
30
/* An implementation of mutexes using semaphores */
#include "SDL_thread.h"
#include "SDL_systhread_c.h"
#include <arch/spinlock.h>
May 28, 2006
May 28, 2006
31
32
33
34
35
struct SDL_mutex
{
int recursive;
Uint32 owner;
spinlock_t mutex;
36
37
38
};
/* Create a mutex */
May 28, 2006
May 28, 2006
39
SDL_mutex *
May 29, 2006
May 29, 2006
40
SDL_CreateMutex(void)
May 28, 2006
May 28, 2006
42
43
44
SDL_mutex *mutex;
/* Allocate mutex memory */
May 29, 2006
May 29, 2006
45
mutex = (SDL_mutex *) SDL_malloc(sizeof(*mutex));
May 28, 2006
May 28, 2006
46
if (mutex) {
May 29, 2006
May 29, 2006
47
spinlock_init(&mutex->mutex);
May 28, 2006
May 28, 2006
48
49
50
mutex->recursive = 0;
mutex->owner = 0;
} else {
May 29, 2006
May 29, 2006
51
SDL_OutOfMemory();
May 28, 2006
May 28, 2006
52
53
}
return mutex;
54
55
56
}
/* Free the mutex */
May 28, 2006
May 28, 2006
57
void
May 29, 2006
May 29, 2006
58
SDL_DestroyMutex(SDL_mutex * mutex)
May 28, 2006
May 28, 2006
60
if (mutex) {
May 29, 2006
May 29, 2006
61
SDL_free(mutex);
May 28, 2006
May 28, 2006
62
}
63
64
65
}
/* Lock the semaphore */
May 28, 2006
May 28, 2006
66
int
May 29, 2006
May 29, 2006
67
SDL_mutexP(SDL_mutex * mutex)
Feb 16, 2006
Feb 16, 2006
69
#if SDL_THREADS_DISABLED
May 29, 2006
May 29, 2006
70
return SDL_arraysize(return), 0;
May 28, 2006
May 28, 2006
72
73
74
Uint32 this_thread;
if (mutex == NULL) {
May 29, 2006
May 29, 2006
75
SDL_SetError("Passed a NULL mutex");
May 28, 2006
May 28, 2006
76
77
78
return -1;
}
May 29, 2006
May 29, 2006
79
this_thread = SDL_ThreadID();
May 28, 2006
May 28, 2006
80
81
82
83
84
85
86
if (mutex->owner == this_thread) {
++mutex->recursive;
} else {
/* The order of operations is important.
We set the locking thread id after we obtain the lock
so unlocks from other threads will fail.
*/
May 29, 2006
May 29, 2006
87
spinlock_lock(&mutex->mutex);
May 28, 2006
May 28, 2006
88
89
90
91
92
mutex->owner = this_thread;
mutex->recursive = 0;
}
return 0;
Feb 16, 2006
Feb 16, 2006
93
#endif /* SDL_THREADS_DISABLED */
94
95
96
}
/* Unlock the mutex */
May 28, 2006
May 28, 2006
97
int
May 29, 2006
May 29, 2006
98
SDL_mutexV(SDL_mutex * mutex)
Feb 16, 2006
Feb 16, 2006
100
#if SDL_THREADS_DISABLED
May 28, 2006
May 28, 2006
101
return 0;
May 28, 2006
May 28, 2006
103
if (mutex == NULL) {
May 29, 2006
May 29, 2006
104
SDL_SetError("Passed a NULL mutex");
May 28, 2006
May 28, 2006
105
106
107
108
return -1;
}
/* If we don't own the mutex, we can't unlock it */
May 29, 2006
May 29, 2006
109
110
if (SDL_ThreadID() != mutex->owner) {
SDL_SetError("mutex not owned by this thread");
May 28, 2006
May 28, 2006
111
112
113
114
115
116
117
118
119
120
121
122
return -1;
}
if (mutex->recursive) {
--mutex->recursive;
} else {
/* The order of operations is important.
First reset the owner so another thread doesn't lock
the mutex and set the ownership before we reset it,
then release the lock semaphore.
*/
mutex->owner = 0;
May 29, 2006
May 29, 2006
123
spinlock_unlock(&mutex->mutex);
May 28, 2006
May 28, 2006
124
125
}
return 0;
Feb 16, 2006
Feb 16, 2006
126
#endif /* SDL_THREADS_DISABLED */
May 28, 2006
May 28, 2006
128
129
/* vi: set ts=4 sw=4 expandtab: */