VirtualBox

source: vbox/trunk/src/VBox/Runtime/r3/win/sems-win.cpp@ 8774

Last change on this file since 8774 was 8651, checked in by vboxsync, 17 years ago

Moved the strictness indicators into internal/strict.h.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 8.4 KB
Line 
1/* $Id: sems-win.cpp 8651 2008-05-07 12:16:29Z vboxsync $ */
2/** @file
3 * IPRT - Semaphores, implementation for Windows host platform.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 *
26 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
27 * Clara, CA 95054 USA or visit http://www.sun.com if you need
28 * additional information or have any questions.
29 */
30
31
32/*******************************************************************************
33* Header Files *
34*******************************************************************************/
35#define LOG_GROUP RTLOGGROUP_SEMAPHORE
36#include <Windows.h>
37
38#include <iprt/semaphore.h>
39#include <iprt/thread.h>
40#include <iprt/assert.h>
41#include <iprt/err.h>
42#include "internal/strict.h"
43
44
45/*******************************************************************************
46* Defined Constants And Macros *
47*******************************************************************************/
48/** Converts semaphore to win32 handle. */
49#define SEM2HND(Sem) ((HANDLE)(uintptr_t)Sem)
50
51
52
53RTDECL(int) RTSemEventCreate(PRTSEMEVENT pEventSem)
54{
55 /*
56 * Create the semaphore.
57 * (Auto reset, not signaled, private event object.)
58 */
59 HANDLE hev = CreateEvent(NULL, FALSE, FALSE, NULL);
60 if (hev)
61 {
62 *pEventSem = (RTSEMEVENT)(void *)hev;
63 return VINF_SUCCESS;
64 }
65 return RTErrConvertFromWin32(GetLastError());
66}
67
68
69RTDECL(int) RTSemEventDestroy(RTSEMEVENT EventSem)
70{
71 /*
72 * Close semaphore handle.
73 */
74 if (CloseHandle(SEM2HND(EventSem)))
75 return VINF_SUCCESS;
76 AssertMsgFailed(("Destroy EventSem %p failed, lasterr=%d\n", EventSem, GetLastError()));
77 return RTErrConvertFromWin32(GetLastError());
78}
79
80
81RTDECL(int) RTSemEventWaitNoResume(RTSEMEVENT EventSem, unsigned cMillies)
82{
83 /*
84 * Wait for condition.
85 */
86 int rc = WaitForSingleObjectEx(SEM2HND(EventSem), cMillies == RT_INDEFINITE_WAIT ? INFINITE : cMillies, TRUE);
87 switch (rc)
88 {
89 case WAIT_OBJECT_0: return VINF_SUCCESS;
90 case WAIT_TIMEOUT: return VERR_TIMEOUT;
91 case WAIT_IO_COMPLETION: return VERR_INTERRUPTED;
92 case WAIT_ABANDONED: return VERR_SEM_OWNER_DIED;
93 default:
94 {
95 AssertMsgFailed(("Wait on EventSem %p failed, rc=%d lasterr=%d\n", EventSem, rc, GetLastError()));
96 int rc2 = RTErrConvertFromWin32(GetLastError());
97 if (rc2)
98 return rc2;
99
100 AssertMsgFailed(("WaitForSingleObject(event) -> rc=%d while converted lasterr=%d\n", rc, rc2));
101 return VERR_INTERNAL_ERROR;
102 }
103 }
104}
105
106
107RTDECL(int) RTSemEventSignal(RTSEMEVENT EventSem)
108{
109 /*
110 * Signal the object.
111 */
112 if (SetEvent(SEM2HND(EventSem)))
113 return VINF_SUCCESS;
114 AssertMsgFailed(("Signaling EventSem %p failed, lasterr=%d\n", EventSem, GetLastError()));
115 return RTErrConvertFromWin32(GetLastError());
116}
117
118
119
120
121RTDECL(int) RTSemEventMultiCreate(PRTSEMEVENTMULTI pEventMultiSem)
122{
123 /*
124 * Create the semaphore.
125 * (Manual reset, not signaled, private event object.)
126 */
127 HANDLE hev = CreateEvent(NULL, TRUE, FALSE, NULL);
128 if (hev)
129 {
130 *pEventMultiSem = (RTSEMEVENTMULTI)(void *)hev;
131 return VINF_SUCCESS;
132 }
133 return RTErrConvertFromWin32(GetLastError());
134}
135
136
137RTDECL(int) RTSemEventMultiDestroy(RTSEMEVENTMULTI EventMultiSem)
138{
139 /*
140 * Close semaphore handle.
141 */
142 if (CloseHandle(SEM2HND(EventMultiSem)))
143 return VINF_SUCCESS;
144 AssertMsgFailed(("Destroy EventMultiSem %p failed, lasterr=%d\n", EventMultiSem, GetLastError()));
145 return RTErrConvertFromWin32(GetLastError());
146}
147
148
149RTDECL(int) RTSemEventMultiSignal(RTSEMEVENTMULTI EventMultiSem)
150{
151 /*
152 * Signal the object.
153 */
154 if (SetEvent(SEM2HND(EventMultiSem)))
155 return VINF_SUCCESS;
156 AssertMsgFailed(("Signaling EventMultiSem %p failed, lasterr=%d\n", EventMultiSem, GetLastError()));
157 return RTErrConvertFromWin32(GetLastError());
158}
159
160
161RTDECL(int) RTSemEventMultiReset(RTSEMEVENTMULTI EventMultiSem)
162{
163 /*
164 * Reset the object.
165 */
166 if (ResetEvent(SEM2HND(EventMultiSem)))
167 return VINF_SUCCESS;
168 AssertMsgFailed(("Resetting EventMultiSem %p failed, lasterr=%d\n", EventMultiSem, GetLastError()));
169 return RTErrConvertFromWin32(GetLastError());
170}
171
172
173RTDECL(int) RTSemEventMultiWaitNoResume(RTSEMEVENTMULTI EventMultiSem, unsigned cMillies)
174{
175 /*
176 * Wait for condition.
177 */
178 int rc = WaitForSingleObjectEx(SEM2HND(EventMultiSem), cMillies == RT_INDEFINITE_WAIT ? INFINITE : cMillies, TRUE);
179 switch (rc)
180 {
181 case WAIT_OBJECT_0: return VINF_SUCCESS;
182 case WAIT_TIMEOUT: return VERR_TIMEOUT;
183 case WAIT_IO_COMPLETION: return VERR_INTERRUPTED;
184 case WAIT_ABANDONED: return VERR_SEM_OWNER_DIED;
185 default:
186 {
187 AssertMsgFailed(("Wait on EventMultiSem %p failed, rc=%d lasterr=%d\n", EventMultiSem, rc, GetLastError()));
188 int rc2 = RTErrConvertFromWin32(GetLastError());
189 if (rc2)
190 return rc2;
191
192 AssertMsgFailed(("WaitForSingleObject(event) -> rc=%d while converted lasterr=%d\n", rc, rc2));
193 return VERR_INTERNAL_ERROR;
194 }
195 }
196}
197
198
199
200
201RTDECL(int) RTSemMutexCreate(PRTSEMMUTEX pMutexSem)
202{
203 /*
204 * Create the semaphore.
205 */
206 HANDLE hmtx = CreateMutex(NULL, FALSE, NULL);
207 if (hmtx)
208 {
209 *pMutexSem = (RTSEMMUTEX)(void *)hmtx;
210 return VINF_SUCCESS;
211 }
212
213 return RTErrConvertFromWin32(GetLastError());
214}
215
216
217RTDECL(int) RTSemMutexDestroy(RTSEMMUTEX MutexSem)
218{
219 /*
220 * Close semaphore handle.
221 */
222 if (CloseHandle(SEM2HND(MutexSem)))
223 return VINF_SUCCESS;
224 AssertMsgFailed(("Destroy MutexSem %p failed, lasterr=%d\n", MutexSem, GetLastError()));
225 return RTErrConvertFromWin32(GetLastError());
226}
227
228
229RTDECL(int) RTSemMutexRequestNoResume(RTSEMMUTEX MutexSem, unsigned cMillies)
230{
231 /*
232 * Lock mutex semaphore.
233 */
234 int rc = WaitForSingleObjectEx(SEM2HND(MutexSem), cMillies == RT_INDEFINITE_WAIT ? INFINITE : cMillies, TRUE);
235 switch (rc)
236 {
237 case WAIT_OBJECT_0:
238 {
239#ifdef RTSEMMUTEX_STRICT
240 RTTHREAD Thread = RTThreadSelf();
241 if (Thread != NIL_RTTHREAD)
242 RTThreadWriteLockInc(Thread);
243#endif
244 return VINF_SUCCESS;
245 }
246
247 case WAIT_TIMEOUT: return VERR_TIMEOUT;
248 case WAIT_IO_COMPLETION: return VERR_INTERRUPTED;
249 case WAIT_ABANDONED: return VERR_SEM_OWNER_DIED;
250 default:
251 {
252 AssertMsgFailed(("Wait on MutexSem %p failed, rc=%d lasterr=%d\n", MutexSem, rc, GetLastError()));
253 int rc2 = RTErrConvertFromWin32(GetLastError());
254 if (rc2 != 0)
255 return rc2;
256
257 AssertMsgFailed(("WaitForSingleObject(event) -> rc=%d while converted lasterr=%d\n", rc, rc2));
258 return VERR_INTERNAL_ERROR;
259 }
260 }
261}
262
263RTDECL(int) RTSemMutexRelease(RTSEMMUTEX MutexSem)
264{
265 /*
266 * Unlock mutex semaphore.
267 */
268#ifdef RTSEMMUTEX_STRICT
269 RTTHREAD Thread = RTThreadSelf();
270 if (Thread != NIL_RTTHREAD)
271 RTThreadWriteLockDec(Thread);
272#endif
273 if (ReleaseMutex(SEM2HND(MutexSem)))
274 return VINF_SUCCESS;
275
276#ifdef RTSEMMUTEX_STRICT
277 if (Thread != NIL_RTTHREAD)
278 RTThreadWriteLockInc(Thread);
279#endif
280 AssertMsgFailed(("Release MutexSem %p failed, lasterr=%d\n", MutexSem, GetLastError()));
281 return RTErrConvertFromWin32(GetLastError());
282}
283
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette