VirtualBox

source: vbox/trunk/src/VBox/Runtime/r0drv/linux/semfastmutex-r0drv-linux.c@ 9318

Last change on this file since 9318 was 8245, checked in by vboxsync, 17 years ago

rebranding: IPRT files again.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 4.9 KB
Line 
1/* $Id: semfastmutex-r0drv-linux.c 8245 2008-04-21 17:24:28Z vboxsync $ */
2/** @file
3 * IPRT - Fast Mutex Semaphores, Ring-0 Driver, Linux.
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/*******************************************************************************
34* Header Files *
35*******************************************************************************/
36#include "the-linux-kernel.h"
37#include <iprt/semaphore.h>
38#include <iprt/alloc.h>
39#include <iprt/assert.h>
40#include <iprt/asm.h>
41#include <iprt/err.h>
42#ifdef IPRT_DEBUG_SEMS
43# include <iprt/thread.h>
44#endif
45
46#include "internal/magics.h"
47
48
49/*******************************************************************************
50* Structures and Typedefs *
51*******************************************************************************/
52/**
53 * Wrapper for the linux semaphore structure.
54 */
55typedef struct RTSEMFASTMUTEXINTERNAL
56{
57 /** Magic value (RTSEMFASTMUTEX_MAGIC). */
58 uint32_t u32Magic;
59 /** the linux semaphore. */
60 struct semaphore Semaphore;
61#ifdef IPRT_DEBUG_SEMS
62 /** For check. */
63 RTNATIVETHREAD volatile Owner;
64#endif
65} RTSEMFASTMUTEXINTERNAL, *PRTSEMFASTMUTEXINTERNAL;
66
67
68RTDECL(int) RTSemFastMutexCreate(PRTSEMFASTMUTEX pMutexSem)
69{
70 /*
71 * Allocate.
72 */
73 PRTSEMFASTMUTEXINTERNAL pFastInt;
74 pFastInt = (PRTSEMFASTMUTEXINTERNAL)RTMemAlloc(sizeof(*pFastInt));
75 if (!pFastInt)
76 return VERR_NO_MEMORY;
77
78 /*
79 * Initialize.
80 */
81 pFastInt->u32Magic = RTSEMFASTMUTEX_MAGIC;
82 sema_init(&pFastInt->Semaphore, 1);
83#ifdef IPRT_DEBUG_SEMS
84 pFastInt->Owner = NIL_RTNATIVETHREAD;
85#endif
86 *pMutexSem = pFastInt;
87 return VINF_SUCCESS;
88}
89
90
91RTDECL(int) RTSemFastMutexDestroy(RTSEMFASTMUTEX MutexSem)
92{
93 /*
94 * Validate.
95 */
96 PRTSEMFASTMUTEXINTERNAL pFastInt = (PRTSEMFASTMUTEXINTERNAL)MutexSem;
97 if (!pFastInt)
98 return VERR_INVALID_PARAMETER;
99 if (pFastInt->u32Magic != RTSEMFASTMUTEX_MAGIC)
100 {
101 AssertMsgFailed(("pFastInt->u32Magic=%RX32 pMutexInt=%p\n", pFastInt->u32Magic, pFastInt));
102 return VERR_INVALID_PARAMETER;
103 }
104
105 ASMAtomicIncU32(&pFastInt->u32Magic);
106 RTMemFree(pFastInt);
107 return VINF_SUCCESS;
108}
109
110
111RTDECL(int) RTSemFastMutexRequest(RTSEMFASTMUTEX MutexSem)
112{
113 /*
114 * Validate.
115 */
116 PRTSEMFASTMUTEXINTERNAL pFastInt = (PRTSEMFASTMUTEXINTERNAL)MutexSem;
117 if ( !pFastInt
118 || pFastInt->u32Magic != RTSEMFASTMUTEX_MAGIC)
119 {
120 AssertMsgFailed(("pFastInt->u32Magic=%RX32 pMutexInt=%p\n", pFastInt ? pFastInt->u32Magic : 0, pFastInt));
121 return VERR_INVALID_PARAMETER;
122 }
123
124#ifdef IPRT_DEBUG_SEMS
125 snprintf(current->comm, TASK_COMM_LEN, "d%lx", IPRT_DEBUG_SEMS_ADDRESS(pFastInt));
126#endif
127 down(&pFastInt->Semaphore);
128#ifdef IPRT_DEBUG_SEMS
129 snprintf(current->comm, TASK_COMM_LEN, "o%lx", IPRT_DEBUG_SEMS_ADDRESS(pFastInt));
130 AssertRelease(pFastInt->Owner == NIL_RTNATIVETHREAD);
131 ASMAtomicUoWriteSize(&pFastInt->Owner, RTThreadNativeSelf());
132#endif
133 return VINF_SUCCESS;
134}
135
136
137RTDECL(int) RTSemFastMutexRelease(RTSEMFASTMUTEX MutexSem)
138{
139 /*
140 * Validate.
141 */
142 PRTSEMFASTMUTEXINTERNAL pFastInt = (PRTSEMFASTMUTEXINTERNAL)MutexSem;
143 if ( !pFastInt
144 || pFastInt->u32Magic != RTSEMFASTMUTEX_MAGIC)
145 {
146 AssertMsgFailed(("pFastInt->u32Magic=%RX32 pMutexInt=%p\n", pFastInt ? pFastInt->u32Magic : 0, pFastInt));
147 return VERR_INVALID_PARAMETER;
148 }
149
150#ifdef IPRT_DEBUG_SEMS
151 AssertRelease(pFastInt->Owner == RTThreadNativeSelf());
152 ASMAtomicUoWriteSize(&pFastInt->Owner, NIL_RTNATIVETHREAD);
153#endif
154 up(&pFastInt->Semaphore);
155#ifdef IPRT_DEBUG_SEMS
156 snprintf(current->comm, TASK_COMM_LEN, "u%lx", IPRT_DEBUG_SEMS_ADDRESS(pFastInt));
157#endif
158 return VINF_SUCCESS;
159}
160
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