VirtualBox

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

Last change on this file since 25722 was 25722, checked in by vboxsync, 15 years ago

iprt/RTSemFastMutex: A little cleanup.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 4.8 KB
Line 
1/* $Id: semfastmutex-r0drv-linux.c 25722 2010-01-11 14:22:03Z 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* Header Files *
34*******************************************************************************/
35#include "the-linux-kernel.h"
36#include "internal/iprt.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 phFastMtx)
69{
70 /*
71 * Allocate.
72 */
73 PRTSEMFASTMUTEXINTERNAL pThis;
74 pThis = (PRTSEMFASTMUTEXINTERNAL)RTMemAlloc(sizeof(*pThis));
75 if (!pThis)
76 return VERR_NO_MEMORY;
77
78 /*
79 * Initialize.
80 */
81 pThis->u32Magic = RTSEMFASTMUTEX_MAGIC;
82 sema_init(&pThis->Semaphore, 1);
83#ifdef IPRT_DEBUG_SEMS
84 pThis->Owner = NIL_RTNATIVETHREAD;
85#endif
86
87 *phFastMtx = pThis;
88 return VINF_SUCCESS;
89}
90RT_EXPORT_SYMBOL(RTSemFastMutexCreate);
91
92
93RTDECL(int) RTSemFastMutexDestroy(RTSEMFASTMUTEX hFastMtx)
94{
95 /*
96 * Validate.
97 */
98 PRTSEMFASTMUTEXINTERNAL pThis = hFastMtx;
99 if (pThis == NIL_RTSEMFASTMUTEX)
100 return VINF_SUCCESS;
101 AssertPtrReturn(pThis, VERR_INVALID_HANDLE);
102 AssertMsgReturn(pThis->u32Magic == RTSEMFASTMUTEX_MAGIC, ("u32Magic=%RX32 pThis=%p\n", pThis->u32Magic, pThis), VERR_INVALID_HANDLE);
103
104 ASMAtomicWriteU32(&pThis->u32Magic, RTSEMFASTMUTEX_MAGIC_DEAD);
105 RTMemFree(pThis);
106 return VINF_SUCCESS;
107}
108RT_EXPORT_SYMBOL(RTSemFastMutexDestroy);
109
110
111RTDECL(int) RTSemFastMutexRequest(RTSEMFASTMUTEX hFastMtx)
112{
113 /*
114 * Validate.
115 */
116 PRTSEMFASTMUTEXINTERNAL pThis = hFastMtx;
117 AssertPtrReturn(pThis, VERR_INVALID_HANDLE);
118 AssertMsgReturn(pThis->u32Magic == RTSEMFASTMUTEX_MAGIC, ("u32Magic=%RX32 pThis=%p\n", pThis->u32Magic, pThis), VERR_INVALID_HANDLE);
119
120#ifdef IPRT_DEBUG_SEMS
121 snprintf(current->comm, TASK_COMM_LEN, "d%lx", IPRT_DEBUG_SEMS_ADDRESS(pThis));
122#endif
123 down(&pThis->Semaphore);
124#ifdef IPRT_DEBUG_SEMS
125 snprintf(current->comm, TASK_COMM_LEN, "o%lx", IPRT_DEBUG_SEMS_ADDRESS(pThis));
126 AssertRelease(pThis->Owner == NIL_RTNATIVETHREAD);
127 ASMAtomicUoWriteSize(&pThis->Owner, RTThreadNativeSelf());
128#endif
129 return VINF_SUCCESS;
130}
131RT_EXPORT_SYMBOL(RTSemFastMutexRequest);
132
133
134RTDECL(int) RTSemFastMutexRelease(RTSEMFASTMUTEX hFastMtx)
135{
136 /*
137 * Validate.
138 */
139 PRTSEMFASTMUTEXINTERNAL pThis = hFastMtx;
140 AssertPtrReturn(pThis, VERR_INVALID_HANDLE);
141 AssertMsgReturn(pThis->u32Magic == RTSEMFASTMUTEX_MAGIC, ("u32Magic=%RX32 pThis=%p\n", pThis->u32Magic, pThis), VERR_INVALID_HANDLE);
142
143#ifdef IPRT_DEBUG_SEMS
144 AssertRelease(pThis->Owner == RTThreadNativeSelf());
145 ASMAtomicUoWriteSize(&pThis->Owner, NIL_RTNATIVETHREAD);
146#endif
147 up(&pThis->Semaphore);
148#ifdef IPRT_DEBUG_SEMS
149 snprintf(current->comm, TASK_COMM_LEN, "u%lx", IPRT_DEBUG_SEMS_ADDRESS(pThis));
150#endif
151 return VINF_SUCCESS;
152}
153RT_EXPORT_SYMBOL(RTSemFastMutexRelease);
154
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