VirtualBox

source: vbox/trunk/src/VBox/Additions/common/VBoxGuestLib/VBoxGuestR3LibEvent.cpp@ 31409

Last change on this file since 31409 was 29291, checked in by vboxsync, 14 years ago

VbglR3: Don't trigger debug assertion in VbglR3WaitEvent(); happens for memory ballooning when running VBoxService w/ older Guest Additions.

  • Property svn:eol-style set to native
  • Property svn:keyword set to Id
  • Property svn:keywords set to Id
File size: 3.8 KB
Line 
1/* $Id: VBoxGuestR3LibEvent.cpp 29291 2010-05-10 10:12:44Z vboxsync $ */
2/** @file
3 * VBoxGuestR3Lib - Ring-3 Support Library for VirtualBox guest additions, Events.
4 */
5
6/*
7 * Copyright (C) 2007-2010 Oracle Corporation
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
27
28/*******************************************************************************
29* Header Files *
30*******************************************************************************/
31#include <VBox/log.h>
32#include "VBGLR3Internal.h"
33
34
35/**
36 * Wait for the host to signal one or more events and return which.
37 *
38 * The events will only be delivered by the host if they have been enabled
39 * previously using @a VbglR3CtlFilterMask. If one or several of the events
40 * have already been signalled but not yet waited for, this function will return
41 * immediately and return those events.
42 *
43 * @returns IPRT status code.
44 *
45 * @param fMask The events we want to wait for, or-ed together.
46 * @param cMillies How long to wait before giving up and returning
47 * (VERR_TIMEOUT). Use RT_INDEFINITE_WAIT to wait until we
48 * are interrupted or one of the events is signalled.
49 * @param pfEvents Where to store the events signalled. Optional.
50 */
51VBGLR3DECL(int) VbglR3WaitEvent(uint32_t fMask, uint32_t cMillies, uint32_t *pfEvents)
52{
53 LogFlow(("VbglR3WaitEvent: fMask=0x%x, cMillies=%u, pfEvents=%p\n",
54 fMask, cMillies, pfEvents));
55 AssertReturn((fMask & ~VMMDEV_EVENT_VALID_EVENT_MASK) == 0, VERR_INVALID_PARAMETER);
56 AssertPtrNullReturn(pfEvents, VERR_INVALID_POINTER);
57
58 VBoxGuestWaitEventInfo waitEvent;
59 waitEvent.u32TimeoutIn = cMillies;
60 waitEvent.u32EventMaskIn = fMask;
61 waitEvent.u32Result = VBOXGUEST_WAITEVENT_ERROR;
62 waitEvent.u32EventFlagsOut = 0;
63 int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_WAITEVENT, &waitEvent, sizeof(waitEvent));
64 if (RT_SUCCESS(rc))
65 {
66 /*
67 * If a guest requests for an event which is not available on the host side
68 * (because of an older host version, a disabled feature or older Guest Additions),
69 * don't trigger an assertion here even in debug builds - would be annoying.
70 */
71#if 0
72 AssertMsg(waitEvent.u32Result == VBOXGUEST_WAITEVENT_OK, ("%d rc=%Rrc\n", waitEvent.u32Result, rc));
73#endif
74 if (pfEvents)
75 *pfEvents = waitEvent.u32EventFlagsOut;
76 }
77
78 LogFlow(("VbglR3WaitEvent: rc=%Rrc, u32EventFlagsOut=0x%x. u32Result=%d\n",
79 rc, waitEvent.u32EventFlagsOut, waitEvent.u32Result));
80 return rc;
81}
82
83
84/**
85 * Cause any pending WaitEvent calls (VBOXGUEST_IOCTL_WAITEVENT) to return
86 * with a VERR_INTERRUPTED status.
87 *
88 * Can be used in combination with a termination flag variable for interrupting
89 * event loops. Avoiding race conditions is the responsibility of the caller.
90 *
91 * @returns IPRT status code.
92 */
93VBGLR3DECL(int) VbglR3InterruptEventWaits(void)
94{
95 return vbglR3DoIOCtl(VBOXGUEST_IOCTL_CANCEL_ALL_WAITEVENTS, 0, 0);
96}
97
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