6
* Copyright (C) 2006-2007 Sun Microsystems, Inc.
8
* This file is part of VirtualBox Open Source Edition (OSE), as
9
* available from http://www.virtualbox.org. This file is free software;
10
* you can redistribute it and/or modify it under the terms of the GNU
11
* General Public License (GPL) as published by the Free Software
12
* Foundation, in version 2 as it comes in the "COPYING" file of the
13
* VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14
* hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
17
* Clara, CA 95054 USA or visit http://www.sun.com if you need
18
* additional information or have any questions.
21
#include "the-linux-kernel.h"
23
#include "waitcompat.h"
30
vboxadd_hgcm_callback (VMMDevHGCMRequestHeader *pHeader, void *pvData, uint32_t u32Data)
32
VBoxDevice *dev = pvData;
33
if (u32Data == RT_INDEFINITE_WAIT)
34
wait_event (dev->eventq, pHeader->fu32Flags & VBOX_HGCM_REQ_DONE);
36
wait_event_timeout (dev->eventq, pHeader->fu32Flags & VBOX_HGCM_REQ_DONE,
37
msecs_to_jiffies (u32Data));
41
vboxadd_hgcm_callback_interruptible (VMMDevHGCMRequestHeader *pHeader, void *pvData, uint32_t u32Data)
43
VBoxDevice *dev = pvData;
44
if (u32Data == RT_INDEFINITE_WAIT)
45
wait_event_interruptible (dev->eventq, pHeader->fu32Flags & VBOX_HGCM_REQ_DONE);
47
wait_event_interruptible_timeout (dev->eventq, pHeader->fu32Flags & VBOX_HGCM_REQ_DONE,
48
msecs_to_jiffies (u32Data));
51
DECLVBGL (int) vboxadd_cmc_call (void *opaque, uint32_t func, void *data)
53
int rc = VINF_SUCCESS;
55
/* this function can handle cancelled requests */
56
if ( VBOXGUEST_IOCTL_STRIP_SIZE(func)
57
== VBOXGUEST_IOCTL_STRIP_SIZE(VBOXGUEST_IOCTL_HGCM_CALL(0)))
58
rc = VbglHGCMCall (data, vboxadd_hgcm_callback_interruptible, opaque, RT_INDEFINITE_WAIT);
59
/* this function can handle cancelled requests */
60
else if ( VBOXGUEST_IOCTL_STRIP_SIZE(func)
61
== VBOXGUEST_IOCTL_STRIP_SIZE(VBOXGUEST_IOCTL_HGCM_CALL_TIMED(0)))
63
VBoxGuestHGCMCallInfoTimed *pCallInfo;
64
pCallInfo = (VBoxGuestHGCMCallInfoTimed *) data;
65
if (pCallInfo->fInterruptible)
66
rc = VbglHGCMCall (&pCallInfo->info, vboxadd_hgcm_callback_interruptible,
67
opaque, pCallInfo->u32Timeout);
69
rc = VbglHGCMCall (&pCallInfo->info, vboxadd_hgcm_callback,
70
opaque, pCallInfo->u32Timeout);
74
/* this function can NOT handle cancelled requests */
75
case VBOXGUEST_IOCTL_HGCM_CONNECT:
76
rc = VbglHGCMConnect (data, vboxadd_hgcm_callback, opaque, RT_INDEFINITE_WAIT);
79
/* this function can NOT handle cancelled requests */
80
case VBOXGUEST_IOCTL_HGCM_DISCONNECT:
81
rc = VbglHGCMDisconnect (data, vboxadd_hgcm_callback, opaque, RT_INDEFINITE_WAIT);
84
case VBOXGUEST_IOCTL_GETVMMDEVPORT:
86
VBoxDevice *pDev = (VBoxDevice *)opaque;
87
VBoxGuestPortInfo *pInfo = (VBoxGuestPortInfo *)data;
88
pInfo->portAddress = pDev->io_port;
89
pInfo->pVMMDevMemory = pDev->pVMMDevMemory;
93
rc = VERR_VBGL_IOCTL_FAILED;
98
int vboxadd_cmc_init (void)
103
void vboxadd_cmc_fini (void)
108
vboxadd_cmc_ctl_guest_filter_mask (uint32_t or_mask, uint32_t not_mask)
111
VMMDevCtlGuestFilterMask *req;
113
rc = VbglGRAlloc ((VMMDevRequestHeader**) &req, sizeof (*req),
114
VMMDevReq_CtlGuestFilterMask);
118
elog ("VbglGRAlloc (CtlGuestFilterMask) failed rc=%d\n", rc);
122
req->u32OrMask = or_mask;
123
req->u32NotMask = not_mask;
125
rc = VbglGRPerform (&req->header);
126
VbglGRFree (&req->header);
129
elog ("VbglGRPerform (CtlGuestFilterMask) failed rc=%d\n", rc);
135
EXPORT_SYMBOL (vboxadd_cmc_call);
136
EXPORT_SYMBOL (vboxadd_cmc_ctl_guest_filter_mask);