~ubuntu-branches/ubuntu/trusty/virtualbox/trusty-proposed

« back to all changes in this revision

Viewing changes to src/VBox/Runtime/r0drv/solaris/semmutex-r0drv-solaris.c

  • Committer: Package Import Robot
  • Author(s): Felix Geyer
  • Date: 2013-03-07 16:38:36 UTC
  • mfrom: (1.1.13) (3.1.20 experimental)
  • Revision ID: package-import@ubuntu.com-20130307163836-p93jpbgx39tp3gb4
Tags: 4.2.8-dfsg-0ubuntu1
* New upstream release. (Closes: #691148)
  - Fixes compatibility with kernel 3.8. (Closes: #700823; LP: #1101867)
* Switch to my @debian.org email address.
* Move package to contrib as virtualbox 4.2 needs a non-free compiler to
  build the BIOS.
* Build-depend on libdevmapper-dev.
* Refresh patches.
  - Drop 36-fix-ftbfs-xserver-112.patch, cve-2012-3221.patch,
    CVE-2013-0420.patch 37-kcompat-3.6.patch and 38-kcompat-3.7.patch.
* Drop all virtualbox-ose transitional packages.
* Drop the virtualbox-fuse package as vdfuse fails to build with
  virtualbox 4.2.
* Update install files and VBox.sh.
* Bump required kbuild version to 0.1.9998svn2577.
* Fix path to VBoxCreateUSBNode.sh in virtualbox.postinst. (Closes: #700479)
* Add an init script to virtuabox-guest-x11 which loads the vboxvideo
  kernel module. The X Server 1.13 doesn't load it anymore. (Closes: #686994)
* Update man pages. (Closes: #680053)
* Add 36-python-multiarch.patch from Rico Tzschichholz to fix detection of
  python in multiarch paths using pkg-config.

Show diffs side-by-side

added added

removed removed

Lines of Context:
4
4
 */
5
5
 
6
6
/*
7
 
 * Copyright (C) 2006-2010 Oracle Corporation
 
7
 * Copyright (C) 2006-2012 Oracle Corporation
8
8
 *
9
9
 * This file is part of VirtualBox Open Source Edition (OSE), as
10
10
 * available from http://www.virtualbox.org. This file is free software;
146
146
 
147
147
 
148
148
/**
149
 
 * Worker for rtSemMutexSolarisRequest that handles the case where we go to sleep.
 
149
 * Worker for rtSemMutexSolRequest that handles the case where we go to sleep.
150
150
 *
151
151
 * @returns VINF_SUCCESS, VERR_INTERRUPTED, or VERR_SEM_DESTROYED.
152
152
 *          Returns without owning the mutex.
156
156
 *
157
157
 * @remarks This needs to be called with the mutex object held!
158
158
 */
159
 
static int rtSemMutexSolarisRequestSleep(PRTSEMMUTEXINTERNAL pThis, RTMSINTERVAL cMillies,
 
159
static int rtSemMutexSolRequestSleep(PRTSEMMUTEXINTERNAL pThis, RTMSINTERVAL cMillies,
160
160
                                       bool fInterruptible)
161
161
{
162
162
    int rc = VERR_GENERAL_FAILURE;
253
253
/**
254
254
 * Internal worker.
255
255
 */
256
 
DECLINLINE(int) rtSemMutexSolarisRequest(RTSEMMUTEX hMutexSem, RTMSINTERVAL cMillies, bool fInterruptible)
 
256
DECLINLINE(int) rtSemMutexSolRequest(RTSEMMUTEX hMutexSem, RTMSINTERVAL cMillies, bool fInterruptible)
257
257
{
258
258
    PRTSEMMUTEXINTERNAL pThis = hMutexSem;
259
259
    int rc = VERR_GENERAL_FAILURE;
295
295
     * No, we really need to get to sleep.
296
296
     */
297
297
    else
298
 
        rc = rtSemMutexSolarisRequestSleep(pThis, cMillies, fInterruptible);
 
298
        rc = rtSemMutexSolRequestSleep(pThis, cMillies, fInterruptible);
299
299
 
300
300
    mutex_exit(&pThis->Mtx);
301
301
    return rc;
304
304
 
305
305
RTDECL(int) RTSemMutexRequest(RTSEMMUTEX hMutexSem, RTMSINTERVAL cMillies)
306
306
{
307
 
    return rtSemMutexSolarisRequest(hMutexSem, cMillies, false /*fInterruptible*/);
 
307
    return rtSemMutexSolRequest(hMutexSem, cMillies, false /*fInterruptible*/);
308
308
}
309
309
 
310
310
 
316
316
 
317
317
RTDECL(int) RTSemMutexRequestNoResume(RTSEMMUTEX hMutexSem, RTMSINTERVAL cMillies)
318
318
{
319
 
    return rtSemMutexSolarisRequest(hMutexSem, cMillies, true /*fInterruptible*/);
 
319
    return rtSemMutexSolRequest(hMutexSem, cMillies, true /*fInterruptible*/);
320
320
}
321
321
 
322
322