VirtualBox

source: vbox/trunk/src/VBox/Additions/common/VBoxGuest/VBoxGuest-win.h@ 69922

Last change on this file since 69922 was 69500, checked in by vboxsync, 7 years ago

*: scm --update-copyright-year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.6 KB
Line 
1/* $Id: VBoxGuest-win.h 69500 2017-10-28 15:14:05Z vboxsync $ */
2/** @file
3 * VBoxGuest - Windows specifics.
4 */
5
6/*
7 * Copyright (C) 2010-2017 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#ifndef ___VBoxGuest_win_h
28#define ___VBoxGuest_win_h
29
30
31#include <iprt/cdefs.h>
32
33#include <iprt/nt/ntddk.h>
34
35#include <iprt/spinlock.h>
36#include <iprt/memobj.h>
37
38#include <VBox/VMMDev.h>
39#include <VBox/VBoxGuest.h>
40#include "VBoxGuestInternal.h"
41
42
43
44/** Possible device states for our state machine. */
45typedef enum VGDRVNTDEVSTATE
46{
47 VGDRVNTDEVSTATE_STOPPED,
48 VGDRVNTDEVSTATE_WORKING,
49 VGDRVNTDEVSTATE_PENDINGSTOP,
50 VGDRVNTDEVSTATE_PENDINGREMOVE,
51 VGDRVNTDEVSTATE_SURPRISEREMOVED,
52 VGDRVNTDEVSTATE_REMOVED
53} VGDRVNTDEVSTATE;
54
55typedef struct VBOXGUESTWINBASEADDRESS
56{
57 /** Original device physical address. */
58 PHYSICAL_ADDRESS RangeStart;
59 /** Length of I/O or memory range. */
60 ULONG RangeLength;
61 /** Flag: Unmapped range is I/O or memory range. */
62 BOOLEAN RangeInMemory;
63 /** Mapped I/O or memory range. */
64 PVOID MappedRangeStart;
65 /** Flag: mapped range is I/O or memory range. */
66 BOOLEAN MappedRangeInMemory;
67 /** Flag: resource is mapped (i.e. MmMapIoSpace called). */
68 BOOLEAN ResourceMapped;
69} VBOXGUESTWINBASEADDRESS, *PVBOXGUESTWINBASEADDRESS;
70
71
72/** Windows-specific device extension bits. */
73typedef struct VBOXGUESTDEVEXTWIN
74{
75 VBOXGUESTDEVEXT Core;
76
77 /** Our functional driver object. */
78 PDEVICE_OBJECT pDeviceObject;
79 /** Top of the stack. */
80 PDEVICE_OBJECT pNextLowerDriver;
81 /** Currently active Irp. */
82 IRP *pCurrentIrp;
83 /** Interrupt object pointer. */
84 PKINTERRUPT pInterruptObject;
85
86 /** Bus number where the device is located. */
87 ULONG busNumber;
88 /** Slot number where the device is located. */
89 ULONG slotNumber;
90 /** Device interrupt level. */
91 ULONG interruptLevel;
92 /** Device interrupt vector. */
93 ULONG interruptVector;
94 /** Affinity mask. */
95 KAFFINITY interruptAffinity;
96 /** LevelSensitive or Latched. */
97 KINTERRUPT_MODE interruptMode;
98
99 /** PCI base address information. */
100 ULONG pciAddressCount;
101 VBOXGUESTWINBASEADDRESS pciBaseAddress[PCI_TYPE0_ADDRESSES];
102
103 /** Physical address and length of VMMDev memory. */
104 PHYSICAL_ADDRESS vmmDevPhysMemoryAddress;
105 ULONG vmmDevPhysMemoryLength;
106
107 /** Device state. */
108 VGDRVNTDEVSTATE enmDevState;
109 /** The previous device state. */
110 VGDRVNTDEVSTATE enmPrevDevState;
111
112 /** Last system power action set (see VBoxGuestPower). */
113 POWER_ACTION LastSystemPowerAction;
114 /** Preallocated generic request for shutdown. */
115 VMMDevPowerStateRequest *pPowerStateRequest;
116 /** Preallocated VMMDevEvents for IRQ handler. */
117 VMMDevEvents *pIrqAckEvents;
118
119 /** Pre-allocated kernel session data. This is needed
120 * for handling kernel IOCtls. */
121 struct VBOXGUESTSESSION *pKernelSession;
122
123 /** Spinlock protecting MouseNotifyCallback. Required since the consumer is
124 * in a DPC callback and not the ISR. */
125 KSPIN_LOCK MouseEventAccessLock;
126} VBOXGUESTDEVEXTWIN, *PVBOXGUESTDEVEXTWIN;
127
128
129/** NT (windows) version identifier. */
130typedef enum VGDRVNTVER
131{
132 VGDRVNTVER_INVALID = 0,
133 VGDRVNTVER_WINNT4,
134 VGDRVNTVER_WIN2K,
135 VGDRVNTVER_WINXP,
136 VGDRVNTVER_WIN2K3,
137 VGDRVNTVER_WINVISTA,
138 VGDRVNTVER_WIN7,
139 VGDRVNTVER_WIN8,
140 VGDRVNTVER_WIN81,
141 VGDRVNTVER_WIN10
142} VGDRVNTVER;
143extern VGDRVNTVER g_enmVGDrvNtVer;
144
145
146#define VBOXGUEST_UPDATE_DEVSTATE(a_pDevExt, a_enmNewDevState) \
147 do { \
148 (a_pDevExt)->enmPrevDevState = (a_pDevExt)->enmDevState; \
149 (a_pDevExt)->enmDevState = (a_enmNewDevState); \
150 } while (0)
151
152/** CM_RESOURCE_MEMORY_* flags which were used on XP or earlier. */
153#define VBOX_CM_PRE_VISTA_MASK (0x3f)
154
155
156RT_C_DECLS_BEGIN
157
158#ifdef TARGET_NT4
159NTSTATUS vgdrvNt4CreateDevice(PDRIVER_OBJECT pDrvObj, PUNICODE_STRING pRegPath);
160#else
161NTSTATUS vgdrvNtPnP(PDEVICE_OBJECT pDevObj, PIRP pIrp);
162NTSTATUS vgdrvNtPower(PDEVICE_OBJECT pDevObj, PIRP pIrp);
163#endif
164
165/** @name Common routines used in both (PnP and legacy) driver versions.
166 * @{
167 */
168#ifdef TARGET_NT4
169NTSTATUS vgdrvNtInit(PDRIVER_OBJECT pDrvObj, PDEVICE_OBJECT pDevObj, PUNICODE_STRING pRegPath);
170#else
171NTSTATUS vgdrvNtInit(PDEVICE_OBJECT pDevObj, PIRP pIrp);
172#endif
173NTSTATUS vgdrvNtCleanup(PDEVICE_OBJECT pDevObj);
174void vgdrvNtUnmapVMMDevMemory(PVBOXGUESTDEVEXTWIN pDevExt); /**< @todo make static once buggy vgdrvNtInit is fixed. */
175VBOXOSTYPE vgdrvNtVersionToOSType(VGDRVNTVER enmNtVer);
176/** @} */
177
178RT_C_DECLS_END
179
180#ifdef TARGET_NT4
181/*
182 * XP DDK #defines ExFreePool to ExFreePoolWithTag. The latter does not exist
183 * on NT4, so... The same for ExAllocatePool.
184 */
185# undef ExAllocatePool
186# undef ExFreePool
187#endif
188
189#endif /* !___VBoxGuest_win_h */
190
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