VirtualBox

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

Last change on this file since 5228 was 5225, checked in by vboxsync, 17 years ago

semaphore-r0drv-lnx.c split.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 3.4 KB
Line 
1/* $Id: semfastmutex-r0drv-linux.c 5225 2007-10-10 15:06:48Z vboxsync $ */
2/** @file
3 * innotek Portable Runtime - Fast Mutex Semaphores, Ring-0 Driver, Linux.
4 */
5
6/*
7 * Copyright (C) 2006-2007 innotek GmbH
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 as published by the Free Software Foundation,
13 * in version 2 as it comes in the "COPYING" file of the VirtualBox OSE
14 * distribution. VirtualBox OSE is distributed in the hope that it will
15 * be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18
19
20/*******************************************************************************
21* Header Files *
22*******************************************************************************/
23#include "the-linux-kernel.h"
24#include <iprt/semaphore.h>
25#include <iprt/alloc.h>
26#include <iprt/assert.h>
27#include <iprt/asm.h>
28#include <iprt/err.h>
29
30#include "internal/magics.h"
31
32
33/*******************************************************************************
34* Structures and Typedefs *
35*******************************************************************************/
36/**
37 * Wrapper for the linux semaphore structure.
38 */
39typedef struct RTSEMFASTMUTEXINTERNAL
40{
41 /** Magic value (RTSEMFASTMUTEX_MAGIC). */
42 uint32_t u32Magic;
43 /** the linux semaphore. */
44 struct semaphore Semaphore;
45} RTSEMFASTMUTEXINTERNAL, *PRTSEMFASTMUTEXINTERNAL;
46
47
48RTDECL(int) RTSemFastMutexCreate(PRTSEMFASTMUTEX pMutexSem)
49{
50 /*
51 * Allocate.
52 */
53 PRTSEMFASTMUTEXINTERNAL pFastInt;
54 pFastInt = (PRTSEMFASTMUTEXINTERNAL)RTMemAlloc(sizeof(*pFastInt));
55 if (!pFastInt)
56 return VERR_NO_MEMORY;
57
58 /*
59 * Initialize.
60 */
61 pFastInt->u32Magic = RTSEMFASTMUTEX_MAGIC;
62 sema_init(&pFastInt->Semaphore, 1);
63 *pMutexSem = pFastInt;
64 return VINF_SUCCESS;
65}
66
67
68RTDECL(int) RTSemFastMutexDestroy(RTSEMFASTMUTEX MutexSem)
69{
70 /*
71 * Validate.
72 */
73 PRTSEMFASTMUTEXINTERNAL pFastInt = (PRTSEMFASTMUTEXINTERNAL)MutexSem;
74 if (!pFastInt)
75 return VERR_INVALID_PARAMETER;
76 if (pFastInt->u32Magic != RTSEMFASTMUTEX_MAGIC)
77 {
78 AssertMsgFailed(("pFastInt->u32Magic=%RX32 pMutexInt=%p\n", pFastInt->u32Magic, pFastInt));
79 return VERR_INVALID_PARAMETER;
80 }
81
82 ASMAtomicIncU32(&pFastInt->u32Magic);
83 RTMemFree(pFastInt);
84 return VINF_SUCCESS;
85}
86
87
88RTDECL(int) RTSemFastMutexRequest(RTSEMFASTMUTEX MutexSem)
89{
90 /*
91 * Validate.
92 */
93 PRTSEMFASTMUTEXINTERNAL pFastInt = (PRTSEMFASTMUTEXINTERNAL)MutexSem;
94 if ( !pFastInt
95 || pFastInt->u32Magic != RTSEMFASTMUTEX_MAGIC)
96 {
97 AssertMsgFailed(("pFastInt->u32Magic=%RX32 pMutexInt=%p\n", pFastInt ? pFastInt->u32Magic : 0, pFastInt));
98 return VERR_INVALID_PARAMETER;
99 }
100
101 down(&pFastInt->Semaphore);
102 return VINF_SUCCESS;
103}
104
105
106RTDECL(int) RTSemFastMutexRelease(RTSEMFASTMUTEX MutexSem)
107{
108 /*
109 * Validate.
110 */
111 PRTSEMFASTMUTEXINTERNAL pFastInt = (PRTSEMFASTMUTEXINTERNAL)MutexSem;
112 if ( !pFastInt
113 || pFastInt->u32Magic != RTSEMFASTMUTEX_MAGIC)
114 {
115 AssertMsgFailed(("pFastInt->u32Magic=%RX32 pMutexInt=%p\n", pFastInt ? pFastInt->u32Magic : 0, pFastInt));
116 return VERR_INVALID_PARAMETER;
117 }
118
119 up(&pFastInt->Semaphore);
120 return VINF_SUCCESS;
121}
122
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