VirtualBox

source: vbox/trunk/src/VBox/Additions/common/VBoxGuest/VBoxGuestInternal.h@ 29507

Last change on this file since 29507 was 28800, checked in by vboxsync, 15 years ago

Automated rebranding to Oracle copyright/license strings via filemuncher

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 8.3 KB
Line 
1/* $Id: VBoxGuestInternal.h 28800 2010-04-27 08:22:32Z vboxsync $ */
2/** @file
3 * VBoxGuest - Guest Additions Driver.
4 */
5
6/*
7 * Copyright (C) 2007 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
18#ifndef ___VBoxGuestInternal_h
19#define ___VBoxGuestInternal_h
20
21#include <iprt/types.h>
22#include <iprt/semaphore.h>
23#include <iprt/spinlock.h>
24#include <VBox/VMMDev.h>
25#include <VBox/VBoxGuest.h>
26#include <VBox/VBoxGuestLib.h>
27
28
29/** Pointer to the VBoxGuest per session data. */
30typedef struct VBOXGUESTSESSION *PVBOXGUESTSESSION;
31
32/** Pointer to a wait-for-event entry. */
33typedef struct VBOXGUESTWAIT *PVBOXGUESTWAIT;
34
35/**
36 * VBox guest wait for event entry.
37 *
38 * Each waiting thread allocates one of these items and adds
39 * it to the wait list before going to sleep on the event sem.
40 */
41typedef struct VBOXGUESTWAIT
42{
43 /** The next entry in the list. */
44 PVBOXGUESTWAIT volatile pNext;
45 /** The previous entry in the list. */
46 PVBOXGUESTWAIT volatile pPrev;
47 /** The event semaphore. */
48 RTSEMEVENTMULTI Event;
49 /** The events we are waiting on. */
50 uint32_t fReqEvents;
51 /** The events we received. */
52 uint32_t volatile fResEvents;
53 /** The session that's waiting. */
54 PVBOXGUESTSESSION pSession;
55#ifdef VBOX_WITH_HGCM
56 /** The HGCM request we're waiting for to complete. */
57 VMMDevHGCMRequestHeader volatile *pHGCMReq;
58#endif
59} VBOXGUESTWAIT;
60
61/**
62 * VBox guest wait for event list.
63 */
64typedef struct VBOXGUESTWAITLIST
65{
66 /** The head. */
67 PVBOXGUESTWAIT volatile pHead;
68 /** The tail. */
69 PVBOXGUESTWAIT volatile pTail;
70} VBOXGUESTWAITLIST;
71/** Pointer to a wait list. */
72typedef VBOXGUESTWAITLIST *PVBOXGUESTWAITLIST;
73
74
75/**
76 * VBox guest memory balloon.
77 */
78typedef struct VBOXGUESTMEMBALLOON
79{
80 /** Mutext protecting the members below from concurrent access.. */
81 RTSEMFASTMUTEX hMtx;
82 /** The current number of chunks in the balloon. */
83 uint32_t cChunks;
84 /** The maximum number of chunks in the balloon (typically the amount of guest
85 * memory / chunksize). */
86 uint32_t cMaxChunks;
87 /** This is true if we are using RTR0MemObjAllocPhysNC() / RTR0MemObjGetPagePhysAddr()
88 * and false otherwise. */
89 bool fUseKernelAPI;
90 /** The current owner of the balloon.
91 * This is automatically assigned to the first session using the ballooning
92 * API and first released when the session closes. */
93 PVBOXGUESTSESSION pOwner;
94 /** The pointer to the array of memory objects holding the chunks of the
95 * balloon. This array is cMaxChunks in size when present. */
96 PRTR0MEMOBJ paMemObj;
97} VBOXGUESTMEMBALLOON;
98/** Pointer to a memory balloon. */
99typedef VBOXGUESTMEMBALLOON *PVBOXGUESTMEMBALLOON;
100
101
102/**
103 * VBox guest device (data) extension.
104 */
105typedef struct VBOXGUESTDEVEXT
106{
107 /** The base of the adapter I/O ports. */
108 RTIOPORT IOPortBase;
109 /** Pointer to the mapping of the VMMDev adapter memory. */
110 VMMDevMemory volatile *pVMMDevMemory;
111 /** Events we won't permit anyone to filter out. */
112 uint32_t fFixedEvents;
113 /** The memory object reserving space for the guest mappings. */
114 RTR0MEMOBJ hGuestMappings;
115
116 /** Spinlock protecting the signaling and resetting of the wait-for-event
117 * semaphores as well as the event acking in the ISR. */
118 RTSPINLOCK EventSpinlock;
119 /** Preallocated VMMDevEvents for the IRQ handler. */
120 VMMDevEvents *pIrqAckEvents;
121 /** The physical address of pIrqAckEvents. */
122 RTCCPHYS PhysIrqAckEvents;
123 /** Wait-for-event list for threads waiting for multiple events. */
124 VBOXGUESTWAITLIST WaitList;
125#ifdef VBOX_WITH_HGCM
126 /** Wait-for-event list for threads waiting on HGCM async completion.
127 * The entire list is evaluated upon the arrival of an HGCM event, unlike
128 * the other lists which are only evaluated till the first thread has been woken up. */
129 VBOXGUESTWAITLIST HGCMWaitList;
130#endif
131 /** List of free wait-for-event entries. */
132 VBOXGUESTWAITLIST FreeList;
133 /** Mask of pending events. */
134 uint32_t volatile f32PendingEvents;
135 /** Current VMMDEV_EVENT_MOUSE_POSITION_CHANGED sequence number.
136 * Used to implement polling. */
137 uint32_t volatile u32MousePosChangedSeq;
138
139 /** Spinlock various items in the VBOXGUESTSESSION. */
140 RTSPINLOCK SessionSpinlock;
141
142 /** The current clipboard client ID, 0 if no client.
143 * For implementing the VBOXGUEST_IOCTL_CLIPBOARD_CONNECT interface. */
144 uint32_t u32ClipboardClientId;
145
146 /** Memory balloon information for RTR0MemObjAllocPhysNC(). */
147 VBOXGUESTMEMBALLOON MemBalloon;
148
149} VBOXGUESTDEVEXT;
150/** Pointer to the VBoxGuest driver data. */
151typedef VBOXGUESTDEVEXT *PVBOXGUESTDEVEXT;
152
153
154/**
155 * The VBoxGuest per session data.
156 *
157 * @remark Not quite sure whether this will be useful or not, but since
158 * its already there let's keep it for now in case it might come
159 * in handy later.
160 */
161typedef struct VBOXGUESTSESSION
162{
163#if defined(RT_OS_OS2) || defined(RT_OS_FREEBSD) || defined(RT_OS_SOLARIS)
164 /** Pointer to the next session with the same hash. */
165 PVBOXGUESTSESSION pNextHash;
166#endif
167#if defined(RT_OS_OS2)
168 /** The system file number of this session. */
169 uint16_t sfn;
170 uint16_t Alignment; /**< Alignment */
171#endif
172 /** The process (id) of the session.
173 * This is NIL if it's a kernel session. */
174 RTPROCESS Process;
175 /** Which process this session is associated with.
176 * This is NIL if it's a kernel session. */
177 RTR0PROCESS R0Process;
178 /** Pointer to the device extension. */
179 PVBOXGUESTDEVEXT pDevExt;
180
181#ifdef VBOX_WITH_HGCM
182 /** Array containing HGCM client IDs associated with this session.
183 * This will be automatically disconnected when the session is closed. */
184 uint32_t volatile aHGCMClientIds[8];
185#endif
186 /** The last consumed VMMDEV_EVENT_MOUSE_POSITION_CHANGED sequence number.
187 * Used to implement polling. */
188 uint32_t volatile u32MousePosChangedSeq;
189
190} VBOXGUESTSESSION;
191
192RT_C_DECLS_BEGIN
193
194int VBoxGuestInitDevExt(PVBOXGUESTDEVEXT pDevExt, uint16_t IOPortBase, void *pvMMIOBase, uint32_t cbMMIO, VBOXOSTYPE enmOSType, uint32_t fEvents);
195void VBoxGuestDeleteDevExt(PVBOXGUESTDEVEXT pDevExt);
196bool VBoxGuestCommonISR(PVBOXGUESTDEVEXT pDevExt);
197int VBoxGuestSetGuestCapabilities(uint32_t fOr, uint32_t fNot);
198
199int VBoxGuestCreateUserSession(PVBOXGUESTDEVEXT pDevExt, PVBOXGUESTSESSION *ppSession);
200int VBoxGuestCreateKernelSession(PVBOXGUESTDEVEXT pDevExt, PVBOXGUESTSESSION *ppSession);
201void VBoxGuestCloseSession(PVBOXGUESTDEVEXT pDevExt, PVBOXGUESTSESSION pSession);
202
203int VBoxGuestCommonIOCtlFast(unsigned iFunction, PVBOXGUESTDEVEXT pDevExt, PVBOXGUESTSESSION pSession);
204int VBoxGuestCommonIOCtl(unsigned iFunction, PVBOXGUESTDEVEXT pDevExt, PVBOXGUESTSESSION pSession,
205 void *pvData, size_t cbData, size_t *pcbDataReturned);
206
207#if defined(RT_OS_SOLARIS) \
208 || defined(RT_OS_FREEBSD) \
209 || defined(RT_OS_LINUX)
210DECLVBGL(void *) VBoxGuestNativeServiceOpen(uint32_t *pu32Version);
211DECLVBGL(void) VBoxGuestNativeServiceClose(void *pvOpaque);
212DECLVBGL(int) VBoxGuestNativeServiceCall(void *pvOpaque, unsigned int iCmd, void *pvData, size_t cbSize, size_t *pcbReturn);
213#endif
214
215/**
216 * ISR callback for notifying threads polling for mouse events.
217 *
218 * This is called at the end of the ISR, after leaving the event spinlock, if
219 * VMMDEV_EVENT_MOUSE_POSITION_CHANGED was raised by the host.
220 *
221 * @param pDevExt The device extension.
222 */
223void VBoxGuestNativeISRMousePollEvent(PVBOXGUESTDEVEXT pDevExt);
224
225RT_C_DECLS_END
226
227#endif
228
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