VirtualBox

source: vbox/trunk/src/VBox/Additions/common/VBoxGuestLib/VBoxGuestR3LibMisc.cpp@ 67314

Last change on this file since 67314 was 67314, checked in by vboxsync, 8 years ago

bugref:8533: Additions/x11: fully support VMSVGA
Add VbglR3AcquireGuestCaps() to the R3 guest library.

This change creates a guest library wrapper for the
VBOXGUEST_IOCTL_GUEST_CAPS_ACQUIRE VBoxGuest driver IoCtl which was added to
allow several instances of VBoxTray to run at once for different users in
Windows guests, but only one at a given time to receive display change and
seamless notifications. VBoxClient --vmsvga can use this to prevent the
privileged kernel mode-setting daemon version and the X11 client version
listening for display change notifications at the same time.

  • Property svn:eol-style set to native
  • Property svn:keyword set to Id
  • Property svn:keywords set to Id Revision
File size: 4.6 KB
Line 
1/* $Id: VBoxGuestR3LibMisc.cpp 67314 2017-06-09 10:06:59Z vboxsync $ */
2/** @file
3 * VBoxGuestR3Lib - Ring-3 Support Library for VirtualBox guest additions, Misc.
4 */
5
6/*
7 * Copyright (C) 2007-2016 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 * Change the IRQ filter mask.
37 *
38 * @returns IPRT status code.
39 * @param fOr The OR mask.
40 * @param fNot The NOT mask.
41 */
42VBGLR3DECL(int) VbglR3CtlFilterMask(uint32_t fOr, uint32_t fNot)
43{
44 VBoxGuestFilterMaskInfo Info;
45 Info.u32OrMask = fOr;
46 Info.u32NotMask = fNot;
47 return vbglR3DoIOCtl(VBOXGUEST_IOCTL_CTL_FILTER_MASK, &Info, sizeof(Info));
48}
49
50
51/**
52 * Report a change in the capabilities that we support to the host.
53 *
54 * @returns IPRT status code.
55 * @param fOr Capabilities which have been added.
56 * @param fNot Capabilities which have been removed.
57 *
58 * @todo Move to a different file.
59 */
60VBGLR3DECL(int) VbglR3SetGuestCaps(uint32_t fOr, uint32_t fNot)
61{
62 VBoxGuestSetCapabilitiesInfo Info;
63 Info.u32OrMask = fOr;
64 Info.u32NotMask = fNot;
65 return vbglR3DoIOCtl(VBOXGUEST_IOCTL_SET_GUEST_CAPABILITIES, &Info,
66 sizeof(Info));
67}
68
69
70/**
71 * Acquire capabilities to report to the host. The capabilities which can be
72 * acquired are the same as those reported by @a VbglR3SetGuestCaps, and once
73 * a capability has been acquired once is is switched to "acquire mode" and can
74 * no longer be set using @a VbglR3SetGuestCaps. Capabilities can also be
75 * switched to acquire mode without actually being acquired. A client can not
76 * acquire a capability which has been acquired and not released by another
77 * client. Capabilities acquired are automatically released on session
78 * termination.
79 *
80 * @returns IPRT status code
81 * @returns VERR_RESOURCE_BUSY and acquires nothing if another client has
82 * acquired and not released at least one of the @a fOr capabilities
83 * @param fOr Capabilities to acquire or to switch to acquire mode
84 * @param fNot Capabilities to release
85 * @param fConfig if set, capabilities in @a fOr are switched to acquire mode
86 * but not acquired, and @a fNot is ignored.
87 */
88VBGLR3DECL(int) VbglR3AcquireGuestCaps(uint32_t fOr, uint32_t fNot, bool fConfig)
89{
90 VBoxGuestCapsAquire Info;
91 int rc;
92
93 Info.u32OrMask = fOr;
94 Info.u32NotMask = fNot;
95 Info.enmFlags = fConfig ? VBOXGUESTCAPSACQUIRE_FLAGS_CONFIG_ACQUIRE_MODE
96 : VBOXGUESTCAPSACQUIRE_FLAGS_NONE;
97 rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_GUEST_CAPS_ACQUIRE, &Info, sizeof(Info));
98 if (RT_FAILURE(rc))
99 return rc;
100 return Info.rc;
101}
102
103
104/**
105 * Query the session ID of this VM.
106 *
107 * The session id is an unique identifier that gets changed for each VM start,
108 * reset or restore. Useful for detection a VM restore.
109 *
110 * @returns IPRT status code.
111 * @param pu64IdSession Session id (out). This is NOT changed on
112 * failure, so the caller can depend on this to
113 * deal with backward compatibility (see
114 * VBoxServiceVMInfoWorker() for an example.)
115 */
116VBGLR3DECL(int) VbglR3GetSessionId(uint64_t *pu64IdSession)
117{
118 VMMDevReqSessionId Req;
119
120 vmmdevInitRequest(&Req.header, VMMDevReq_GetSessionId);
121 Req.idSession = 0;
122 int rc = vbglR3GRPerform(&Req.header);
123 if (RT_SUCCESS(rc))
124 *pu64IdSession = Req.idSession;
125
126 return rc;
127}
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