Changeset 32322 in vbox for trunk/src/VBox/Additions
- Timestamp:
- Sep 8, 2010 3:00:46 PM (14 years ago)
- Location:
- trunk/src/VBox/Additions/common/VBoxGuest
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/Additions/common/VBoxGuest/Makefile.kmk
r32317 r32322 35 35 VBoxGuest_DEFS.linux = KBUILD_MODNAME=KBUILD_STR\(vboxguest\) KBUILD_BASENAME=KBUILD_STR\(vboxguest\) DEBUG_HASH=2 DEBUG_HASH2=3 EXPORT_SYMTAB 36 36 VBoxGuest_DEFS.solaris = VBOX_SVN_REV=$(VBOX_SVN_REV) 37 VBoxGuest_DEFS.win = VBOX_SVN_REV=$(VBOX_SVN_REV)# VBOX_WITH_VRDP_SESSION_HANDLING37 VBoxGuest_DEFS.win = # VBOX_WITH_VRDP_SESSION_HANDLING 38 38 ifeq ($(KBUILD_TYPE),release) 39 39 # Allow stopping/removing the driver without a reboot … … 60 60 ifdef VBOX_WITH_GUEST_BUGCHECK_DETECTION 61 61 VBoxGuest_LIBS += \ 62 $(PATH_SDK_WINDDKWLH_LIB)/aux_klib.lib \63 $(PATH_SDK_WINDDKWLH_LIB)/ksecdd.lib \64 $(PATH_SDK_WINDDKWLH_LIB)/BufferOverflowK.lib62 $(PATH_SDK_WINDDKWLH_LIB)/aux_klib.lib \ 63 $(PATH_SDK_WINDDKWLH_LIB)/ksecdd.lib \ 64 $(PATH_SDK_WINDDKWLH_LIB)/BufferOverflowK.lib 65 65 VBoxGuest.cpp_SDKS = WINDDKWLH 66 66 endif … … 74 74 VBoxGuest.cpp \ 75 75 VBoxGuest2.cpp 76 VBoxGuest_SOURCES.win = \ 76 ifeq ($(KBUILD_TARGET), win) 77 VBoxGuest_SOURCES += \ 77 78 VBoxGuest-$(KBUILD_TARGET)-pnp.cpp \ 78 79 win/VBoxGuest.rc 80 endif 79 81 VBoxGuest2.cpp_DEFS = VBOX_SVN_REV=$(VBOX_SVN_REV) 80 82 VBoxGuest.cpp_DEFS = VBOX_SVN_REV=$(VBOX_SVN_REV) … … 119 121 # Windows NT4 driver. 120 122 # 121 #SYSMODS.x86 += VBoxGuestNT # Not yet buildable!123 SYSMODS.x86 += VBoxGuestNT 122 124 VBoxGuestNT_EXTENDS = VBoxGuest 123 125 VBoxGuestNT_NOINST = $(NO_SUCH_VARIABLE) 124 126 VBoxGuestNT_DEFS = $(VBoxGuest_DEFS) TARGET_NT4 125 127 VBoxGuestNT_SOURCES = \ 126 VBoxGuest-$(KBUILD_TARGET).cpp \ 128 VBoxGuest.cpp \ 129 VBoxGuest2.cpp \ 130 VBoxGuest-$(KBUILD_TARGET).cpp \ 127 131 VBoxGuest-$(KBUILD_TARGET)-legacy.cpp \ 128 132 win/VBoxGuest.rc -
trunk/src/VBox/Additions/common/VBoxGuest/VBoxGuest-win-legacy.cpp
r32282 r32322 1 1 /** @file 2 * VBoxGuest -- VirtualBox Win32 guest support driver 3 */ 4 5 /* 6 * Copyright (C) 2006-2010 Oracle Corporation 2 * 3 * VBoxGuest-win-legacy - Windows NT4 specifics. 4 * 5 * Copyright (C) 2010 Oracle Corporation 7 6 * 8 7 * This file is part of VirtualBox Open Source Edition (OSE), as … … 15 14 */ 16 15 17 // enable backdoor logging18 //#define LOG_ENABLED19 20 16 /******************************************************************************* 21 17 * Header Files * 22 18 *******************************************************************************/ 23 #include "NTLegacy.h" 24 #include "Helper.h" 25 19 #include "VBoxGuest-win.h" 20 #include "VBoxGuestInternal.h" 21 #include <VBox/err.h> 22 #include <VBox/log.h> 23 #include <VBox/version.h> 26 24 #include <VBox/VBoxGuestLib.h> 27 #include "../../common/VBoxGuest/VBoxGuest2.h" 25 28 26 29 27 /******************************************************************************* … … 31 29 *******************************************************************************/ 32 30 31 /* Reenable logging, this was #undef'ed on iprt/log.h for RING0. */ 32 #define LOG_ENABLED 33 34 #ifndef PCI_MAX_BUSES 35 # define PCI_MAX_BUSES 256 36 #endif 37 33 38 34 39 /******************************************************************************* 35 40 * Internal Functions * 36 41 *******************************************************************************/ 37 extern "C" 38 { 39 static NTSTATUS findPCIDevice(PULONG pBusNumber, PPCI_SLOT_NUMBER pSlotNumber); 40 static void freeDeviceResources(PDRIVER_OBJECT pDrvObj, PDEVICE_OBJECT pDevObj); 41 } 42 RT_C_DECLS_BEGIN 43 static NTSTATUS vboxguestwinnt4FindPCIDevice(PULONG pBusNumber, PPCI_SLOT_NUMBER pSlotNumber); 44 static void vboxguestwinnt4FreeDeviceResources(PDRIVER_OBJECT pDrvObj, PDEVICE_OBJECT pDevObj); 45 RT_C_DECLS_END 42 46 43 47 #ifdef ALLOC_PRAGMA 44 #pragma alloc_text (INIT, ntCreateDevice)45 #pragma alloc_text (INIT, findPCIDevice)46 #pragma alloc_text (INIT, freeDeviceResources)48 #pragma alloc_text (INIT, vboxguestwinnt4CreateDevice) 49 #pragma alloc_text (INIT, vboxguestwinnt4FindPCIDevice) 50 #pragma alloc_text (INIT, vboxguestwinnt4FreeDeviceResources) 47 51 #endif 52 48 53 49 54 /** … … 53 58 * @param 54 59 */ 55 NTSTATUS ntCreateDevice(PDRIVER_OBJECT pDrvObj, PDEVICE_OBJECT pDevObj, PUNICODE_STRING pRegPath)60 NTSTATUS vboxguestwinnt4CreateDevice(PDRIVER_OBJECT pDrvObj, PDEVICE_OBJECT pDevObj, PUNICODE_STRING pRegPath) 56 61 { 57 ULONG busNumber, slotNumber;58 62 int vrc = VINF_SUCCESS; 59 63 NTSTATUS rc = STATUS_SUCCESS; 60 64 61 dprintf(("VBoxGuest::ntCreateDevice: entered,pDrvObj=%x, pDevObj=%x, pRegPath=%x\n",62 pDrvObj, pDevObj, pRegPath));65 Log(("VBoxGuest::vboxguestwinnt4CreateDevice: pDrvObj=%x, pDevObj=%x, pRegPath=%x\n", 66 pDrvObj, pDevObj, pRegPath)); 63 67 64 68 /* 65 69 * Find our virtual PCI device 66 70 */ 67 rc = findPCIDevice(&busNumber, (PCI_SLOT_NUMBER*)&slotNumber); 68 if (!NT_SUCCESS(rc)) 69 { 70 dprintf(("VBoxGuest::createDevice: device not found, returning\n")); 71 return rc; 72 } 73 74 /* 75 * Create device. 76 */ 77 PDEVICE_OBJECT deviceObject = NULL; 78 UNICODE_STRING DevName; 79 RtlInitUnicodeString(&DevName, VBOXGUEST_DEVICE_NAME_NT); 80 rc = IoCreateDevice(pDrvObj, sizeof(VBOXGUESTDEVEXT), &DevName, FILE_DEVICE_UNKNOWN, 0, FALSE, &deviceObject); 81 if (!NT_SUCCESS(rc)) 82 { 83 dprintf(("VBoxGuest::ntCreateDevice: IoCreateDevice failed with rc=%#x!\n", rc)); 84 return rc; 85 } 86 dprintf(("VBoxGuest::ntCreateDevice: device created\n")); 87 UNICODE_STRING DosName; 88 RtlInitUnicodeString(&DosName, VBOXGUEST_DEVICE_NAME_DOS); 89 rc = IoCreateSymbolicLink(&DosName, &DevName); 90 if (!NT_SUCCESS(rc)) 91 { 92 dprintf(("VBoxGuest::ntCreateDevice: IoCreateSymbolicLink failed with rc=%#x!\n", rc)); 93 IoDeleteDevice(deviceObject); 94 return rc; 95 } 96 dprintf(("VBoxGuest::ntCreateDevice: symlink created\n")); 71 ULONG uBusNumber, uSlotNumber; 72 rc = vboxguestwinnt4FindPCIDevice(&uBusNumber, (PCI_SLOT_NUMBER*)&uSlotNumber); 73 if (NT_ERROR(rc)) 74 Log(("VBoxGuest::vboxguestwinnt4CreateDevice: Device not found!\n")); 75 76 PDEVICE_OBJECT pDeviceObject = NULL; 77 if (NT_SUCCESS(rc)) 78 { 79 /* 80 * Create device. 81 */ 82 UNICODE_STRING szDevName; 83 RtlInitUnicodeString(&szDevName, VBOXGUEST_DEVICE_NAME_NT); 84 rc = IoCreateDevice(pDrvObj, sizeof(VBOXGUESTDEVEXT), &szDevName, FILE_DEVICE_UNKNOWN, 0, FALSE, &pDeviceObject); 85 if (NT_SUCCESS(rc)) 86 { 87 Log(("VBoxGuest::vboxguestwinnt4CreateDevice: Device created\n")); 88 89 UNICODE_STRING DosName; 90 RtlInitUnicodeString(&DosName, VBOXGUEST_DEVICE_NAME_DOS); 91 rc = IoCreateSymbolicLink(&DosName, &szDevName); 92 if (NT_ERROR(rc)) 93 { 94 Log(("VBoxGuest::vboxguestwinnt4CreateDevice: IoCreateSymbolicLink failed with rc = %#x\n", rc)); 95 //IoDeleteDevice(pDeviceObject); 96 } 97 Log(("VBoxGuest::vboxguestwinnt4CreateDevice: Symlink created\n")); 98 } 99 else 100 Log(("VBoxGuest::vboxguestwinnt4CreateDevice: IoCreateDevice failed with rc = %#x\n", rc)); 101 } 97 102 98 103 /* 99 104 * Setup the device extension. 100 105 */ 101 PVBOXGUESTDEVEXT pDevExt = (PVBOXGUESTDEVEXT)deviceObject->DeviceExtension; 102 RtlZeroMemory(pDevExt, sizeof(VBOXGUESTDEVEXT)); 103 104 if (pDevObj) /* pDevObj always is NULL at the moment, so don't attach to the driver stack */ 105 { 106 pDevExt->nextLowerDriver = IoAttachDeviceToDeviceStack(deviceObject, pDevObj); 107 if (pDevExt->nextLowerDriver == NULL) 108 { 109 dprintf(("VBoxGuest::ntCreateDevice: IoAttachDeviceToDeviceStack did not give a nextLowerDrive\n")); 110 IoDeleteSymbolicLink(&DosName); 111 IoDeleteDevice(deviceObject); 112 return STATUS_NO_SUCH_DEVICE; 113 } 114 dprintf(("VBoxGuest::ntCreateDevice: device attached to stack\n")); 115 } 116 117 #ifdef VBOX_WITH_HGCM 118 /* Create global spinlock for all driver sessions */ 119 int rc2 = RTSpinlockCreate(&pDevExt->SessionSpinlock); 120 if (RT_FAILURE(rc2)) 121 { 122 dprintf(("VBoxGuest::ntCreateDevice: RTSpinlockCreate failed\n")); 123 IoDetachDevice(pDevExt->nextLowerDriver); 124 IoDeleteSymbolicLink(&DosName); 125 IoDeleteDevice(deviceObject); 126 return STATUS_DRIVER_UNABLE_TO_LOAD; 127 } 128 dprintf(("VBoxGuest::ntCreateDevice: spinlock created\n")); 129 #endif 130 131 /* Store a reference to ourself */ 132 pDevExt->deviceObject = deviceObject; 133 /* Store bus and slot number we've queried before */ 134 pDevExt->busNumber = busNumber; 135 pDevExt->slotNumber = slotNumber; 136 137 #ifdef VBOX_WITH_GUEST_BUGCHECK_DETECTION 138 rc = hlpRegisterBugCheckCallback(pDevExt); 139 #endif 140 141 // 142 // let's have a look at what our PCI adapter offers 143 // 144 dprintf(("VBoxGuest::ntCreateDevice: starting to scan PCI resources of VBoxGuest\n")); 145 // assign the PCI resources 146 PCM_RESOURCE_LIST resourceList; 147 UNICODE_STRING classNameString; 148 RtlInitUnicodeString(&classNameString, L"VBoxGuestAdapter"); 149 rc = HalAssignSlotResources(pRegPath, &classNameString, 150 pDrvObj, pDevObj, 151 PCIBus, busNumber, slotNumber, 152 &resourceList); 153 if (!NT_SUCCESS(rc)) 154 { 155 dprintf(("VBoxGuest::ntCreateDevice: HalAssignSlotResources failed with rc=%#x!\n", rc)); 156 freeDeviceResources(pDrvObj, pDevObj); 157 return rc; 158 } 159 160 rc = VBoxScanPCIResourceList(resourceList, pDevExt); 161 162 rc = VbglInit (pDevExt->startPortAddress, pDevExt->pVMMDevMemory); 163 if (!RT_SUCCESS(rc)) 164 { 165 dprintf(("VBoxGuest::START_DEVICE: VbglInit failed. rc = %d\n", rc)); 166 } 167 168 169 rc = VbglGRAlloc ((VMMDevRequestHeader **)&pDevExt->irqAckEvents, sizeof (VMMDevEvents), VMMDevReq_AcknowledgeEvents); 170 if (!RT_SUCCESS(rc)) 171 { 172 dprintf(("VBoxGuest::START_DEVICE: VbglAlloc failed for irqAckEvents. rc = %d\n", rc)); 173 } 174 rc = VbglGRAlloc ((VMMDevRequestHeader **)&pDevExt->powerStateRequest, sizeof (VMMDevPowerStateRequest), VMMDevReq_SetPowerStatus); 175 if (!RT_SUCCESS(rc)) 176 { 177 dprintf(("VBoxGuest::START_DEVICE: VbglAlloc failed for powerStateRequest. rc = %d\n", rc)); 178 } 179 180 #if 0 181 // 182 // now proceed to the busmaster DMA stuff 183 // 184 185 DEVICE_DESCRIPTION deviceDescription; 186 ULONG numberOfMapRegisters; 187 deviceDescription.Version = DEVICE_DESCRIPTION_VERSION; 188 deviceDescription.Master = TRUE; 189 deviceDescription.ScatterGather = TRUE; 190 deviceDescription.BusNumber = pDevExt->busNumber; 191 deviceDescription.InterfaceType = PCIBus; 192 deviceDescription.MaximumLength = MAXIMUM_TRANSFER_LENGTH; 193 pDevExt->adapterObject = HalGetAdapter(&deviceDescription, &numberOfMapRegisters); 194 if (pDevExt->adapterObject == NULL) 195 { 196 dprintf(("VBoxGuest::ntCreateDevice: HalGetAdapter failed!\n")); 197 freeDeviceResources(pDrvObj, pDevObj); 198 return rc; 199 } 200 201 // @todo allocate S/G buffer 202 #endif 203 204 205 // 206 // it's time to map the I/O and memory spaces 207 // 208 209 // Map physical address of VMMDev memory 210 rc = hlpVBoxMapVMMDevMemory (pDevExt); 211 if (!NT_SUCCESS(rc)) 212 { 213 dprintf(("VBoxGuest::ntCreateDevice: Unable to map VMMDev Memory, rc=%#x!\n", rc)); 214 freeDeviceResources(pDrvObj, pDevObj); 215 return rc; 216 } 217 218 // 219 // now we need an ISR and DPC 220 // 221 222 // register DPC routine 223 dprintf(("VBoxGuest::ntCreateDevice: initializing DPC...\n")); 224 IoInitializeDpcRequest(pDevExt->deviceObject, VBoxGuestDpcHandler); 225 // get an interrupt vector 226 ULONG vector; 227 KIRQL irql; 228 KAFFINITY affinity; 229 // only proceed if the device provides an interrupt 230 if (pDevExt->interruptLevel || pDevExt->interruptVector) 231 { 232 vector = HalGetInterruptVector(PCIBus, 233 pDevExt->busNumber, 234 pDevExt->interruptLevel, 235 pDevExt->interruptVector, 236 &irql, 237 &affinity); 238 dprintf(("VBoxGuest::ntCreateDevice: HalGetInterruptVector returns vector %u\n", vector)); 239 rc = IoConnectInterrupt(&pDevExt->interruptObject, // out: interrupt object 240 (PKSERVICE_ROUTINE)VBoxGuestIsrHandler, // ISR 241 pDevExt, // context 242 NULL, // optional spinlock 243 vector, // interrupt vector 244 irql, // interrupt level 245 irql, // interrupt level 246 pDevExt->interruptMode, // LevelSensitive or Latched 247 TRUE, // shareable interrupt 248 affinity, // CPU affinity 249 FALSE); // don't save FPU stack 250 if (!NT_SUCCESS(rc)) 251 { 252 dprintf(("VBoxGuest::ntCreateDevice: Unable to connect interrupt, rc=%#x!\n", rc)); 253 pDevExt->interruptObject = NULL; 254 freeDeviceResources(pDrvObj, pDevObj); 255 return rc; 256 } 257 dprintf(("VBoxGuest::ntCreateDevice: IRQ connected!\n")); 258 } 259 106 PVBOXGUESTDEVEXT pDevExt = NULL; 260 107 if (NT_SUCCESS(rc)) 261 108 { 262 // create our thread to inform the VBoxMouse driver 263 rc = createThreads(pDevExt); 109 Log(("VBoxGuest::vboxguestwinnt4CreateDevice: Setting up device extension ...\n")); 110 111 pDevExt = (PVBOXGUESTDEVEXT)pDeviceObject->DeviceExtension; 112 Assert(pDevExt); 113 RtlZeroMemory(pDevExt, sizeof(VBOXGUESTDEVEXT)); 114 } 115 116 if ( NT_SUCCESS(rc) 117 && pDevExt) 118 { 119 /* Store a reference to ourself. */ 120 pDevExt->win.s.pDeviceObject = pDeviceObject; 121 122 /* Store bus and slot number we've queried before. */ 123 pDevExt->win.s.busNumber = uBusNumber; 124 pDevExt->win.s.slotNumber = uSlotNumber; 125 126 #ifdef VBOX_WITH_GUEST_BUGCHECK_DETECTION 127 rc = hlpRegisterBugCheckCallback(pDevExt); 128 #endif 264 129 } 265 130 266 131 if (NT_SUCCESS(rc)) 267 132 { 268 // initialize the event notification semaphore 269 KeInitializeEvent(&pDevExt->keventNotification, NotificationEvent, FALSE); 270 271 /* Preallocated constant timeout 250ms for HGCM async waiter. */ 272 pDevExt->HGCMWaitTimeout.QuadPart = 250; 273 pDevExt->HGCMWaitTimeout.QuadPart *= -10000; /* relative in 100ns units */ 274 } 275 276 /** @todo Cleanup on failure. */ 277 278 /** @todo Don't mix up IPRT rc and NTSTATUS rc above! */ 279 280 if (NT_SUCCESS(rc)) 281 { 282 vrc = VBoxGuestReportGuestInfo(hlpVBoxWinVersionToOSType(winVersion)); 283 if (RT_SUCCESS(vrc)) 284 { 285 vrc = VBoxInitMemBalloon(pDevExt); 286 if (RT_SUCCESS(vrc)) 287 { 288 vrc = VBoxGuestReportDriverStatus(true /* Driver is active */); 289 if (RT_FAILURE(vrc)) 290 dprintf(("VBoxGuest::VBoxGuestPnp::IRP_MN_START_DEVICE: could not report guest driver status, vrc = %d\n", vrc)); 291 } 292 else 293 dprintf(("VBoxGuest::VBoxGuestPnp::IRP_MN_START_DEVICE: could not init mem balloon, vrc = %d\n", vrc)); 294 } 295 else 296 dprintf(("VBoxGuest::VBoxGuestPnp::IRP_MN_START_DEVICE: could not report guest information to host, vrc = %d\n", vrc)); 297 298 if (RT_FAILURE(vrc)) 299 rc = STATUS_UNSUCCESSFUL; 300 } 301 302 if (NT_SUCCESS(rc)) 303 { 304 // ready to rumble! 305 pDevExt->devState = WORKING; 306 } 307 else 308 { 309 freeDeviceResources(pDrvObj, pDevObj); 310 } 311 312 dprintf(("returning from ntCreateDevice with rc = 0x%x\n, vrc = %Rrc", rc, vrc)); 133 rc = vboxguestwinInit(pDrvObj, pDevObj, pRegPath); 134 } 135 136 Log(("VBoxGuest::vboxguestwinnt4CreateDevice: Returning rc = 0x%x\n", rc)); 313 137 return rc; 314 138 } … … 320 144 * @returns NT error codes 321 145 */ 322 static NTSTATUS findPCIDevice(PULONG pBusNumber, PPCI_SLOT_NUMBER pSlotNumber)146 static NTSTATUS vboxguestwinnt4FindPCIDevice(PULONG pBusNumber, PPCI_SLOT_NUMBER pSlotNumber) 323 147 { 324 148 NTSTATUS rc; … … 330 154 PCI_COMMON_CONFIG pciData; 331 155 332 dprintf(("findPCIDevice\n"));156 Log(("VBoxGuest::vboxguestwinnt4FindPCIDevice\n")); 333 157 334 158 rc = STATUS_DEVICE_DOES_NOT_EXIST; 335 159 slotNumber.u.AsULONG = 0; 336 // scan each bus 160 161 /* Scan each bus. */ 337 162 for (busNumber = 0; busNumber < PCI_MAX_BUSES; busNumber++) 338 163 { 339 / / scan each device164 /* Scan each device. */ 340 165 for (deviceNumber = 0; deviceNumber < PCI_MAX_DEVICES; deviceNumber++) 341 166 { 342 167 slotNumber.u.bits.DeviceNumber = deviceNumber; 343 // scan each function (not really required...) 168 169 /* Scan each function (not really required...). */ 344 170 for (functionNumber = 0; functionNumber < PCI_MAX_FUNCTION; functionNumber++) 345 171 { 346 172 slotNumber.u.bits.FunctionNumber = functionNumber; 347 // have a look at what's in this slot 173 174 /* Have a look at what's in this slot. */ 348 175 if (!HalGetBusData(PCIConfiguration, busNumber, slotNumber.u.AsULONG, 349 176 &pciData, sizeof(ULONG))) 350 177 { 351 / / no such bus, we're done with it178 /* No such bus, we're done with it. */ 352 179 deviceNumber = PCI_MAX_DEVICES; 353 180 break; … … 356 183 if (pciData.VendorID == PCI_INVALID_VENDORID) 357 184 { 358 / / we have to proceed to the next function185 /* We have to proceed to the next function. */ 359 186 continue; 360 187 } 361 188 362 / / check if it's another device189 /* Check if it's another device. */ 363 190 if ((pciData.VendorID != VMMDEV_VENDORID) || 364 191 (pciData.DeviceID != VMMDEV_DEVICEID)) … … 367 194 } 368 195 369 // Hooray, we've found it! 370 dprintf(("device found!\n")); 196 /* Hooray, we've found it! */ 197 Log(("VBoxGuest::vboxguestwinnt4FindPCIDevice: Device found!\n")); 198 371 199 *pBusNumber = busNumber; 372 200 *pSlotNumber = slotNumber; … … 379 207 } 380 208 381 /**382 * Helper function to cleanup resources383 *384 * @param pDrvObj Driver object.385 * @param pDevObj Device object.386 */387 static void freeDeviceResources(PDRIVER_OBJECT pDrvObj, PDEVICE_OBJECT pDevObj)388 {389 PVBOXGUESTDEVEXT pDevExt = (PVBOXGUESTDEVEXT)pDevObj->DeviceExtension;390 391 // if there's no device extension, we're screwed392 if (!pDevExt)393 {394 dprintf(("freeDeviceResources: FATAL ERROR! device extension pointer is NULL! Not freeing resources!\n"));395 return;396 }397 398 // indicate that the device is no longer ready399 pDevExt->devState = STOPPED;400 401 // disconnect interrupts402 if (pDevExt->interruptObject)403 {404 IoDisconnectInterrupt(pDevExt->interruptObject);405 }406 407 // unmap mem/io resources408 hlpVBoxUnmapVMMDevMemory (pDevExt);409 410 VBoxCleanupMemBalloon(pDevExt);411 }412 -
trunk/src/VBox/Additions/common/VBoxGuest/VBoxGuest-win-pnp.cpp
r32317 r32322 170 170 else 171 171 { 172 vboxguestwinShowDeviceResources(&pStack->Parameters.StartDevice.AllocatedResources->List[0].PartialResourceList); 173 174 vboxguestwinScanPCIResourceList(pStack->Parameters.StartDevice.AllocatedResourcesTranslated, 175 pDevExt); 176 177 /* Map physical address of VMMDev memory into MMIO region. */ 178 void *pvMMIOBase = NULL; 179 uint32_t cbMMIO = 0; 180 rc = vboxguestwinMapVMMDevMemory(pDevExt, 181 pDevExt->win.s.vmmDevPhysMemoryAddress, 182 pDevExt->win.s.vmmDevPhysMemoryLength, 183 &pvMMIOBase, 184 &cbMMIO); 185 if (NT_SUCCESS(rc)) 186 { 187 pDevExt->pVMMDevMemory = (VMMDevMemory *)pvMMIOBase; 188 189 Log(("VBoxGuest::vboxguestwinVBoxGuestPnP: START_DEVICE: pvMMIOBase = 0x%p, pDevExt = 0x%p, pDevExt->pVMMDevMemory = 0x%p\n", 190 pvMMIOBase, pDevExt, pDevExt ? pDevExt->pVMMDevMemory : NULL)); 191 192 int vrc = VBoxGuestInitDevExt(pDevExt, 193 pDevExt->IOPortBase, 194 pvMMIOBase, cbMMIO, 195 vboxguestwinVersionToOSType(g_winVersion), 196 VMMDEV_EVENT_MOUSE_POSITION_CHANGED); 197 if (RT_FAILURE(vrc)) 198 { 199 Log(("VBoxGuest::vboxguestwinVBoxGuestPnP: START_DEVICE: Could not init device extension, rc = %Rrc!\n", vrc)); 200 rc = STATUS_DEVICE_CONFIGURATION_ERROR; 201 } 202 } 203 else 204 Log(("VBoxGuest::vboxguestwinVBoxGuestPnP: START_DEVICE: Could not map physical address of VMMDev, rc = 0x%x!\n", rc)); 205 206 if (NT_SUCCESS(rc)) 207 { 208 int vrc = VbglGRAlloc((VMMDevRequestHeader **)&pDevExt->win.s.pPowerStateRequest, 209 sizeof (VMMDevPowerStateRequest), VMMDevReq_SetPowerStatus); 210 if (RT_FAILURE(vrc)) 211 { 212 Log(("VBoxGuest::vboxguestwinVBoxGuestPnP: START_DEVICE: Alloc for pPowerStateRequest failed, rc = %Rrc\n", vrc)); 213 rc = STATUS_UNSUCCESSFUL; 214 } 215 } 216 217 if (NT_SUCCESS(rc)) 218 { 219 /* Register DPC and ISR. */ 220 Log(("VBoxGuest::vboxguestwinGuestPnp: START_DEVICE: Initializing DPC/ISR ...\n")); 221 222 IoInitializeDpcRequest(pDevExt->win.s.pDeviceObject, vboxguestwinDpcHandler); 223 rc = IoConnectInterrupt(&pDevExt->win.s.pInterruptObject, /* Out: interrupt object. */ 224 (PKSERVICE_ROUTINE)vboxguestwinIsrHandler, /* Our ISR handler. */ 225 pDevExt, /* Device context. */ 226 NULL, /* Optional spinlock. */ 227 pDevExt->win.s.interruptVector, /* Interrupt vector. */ 228 (KIRQL)pDevExt->win.s.interruptLevel, /* Interrupt level. */ 229 (KIRQL)pDevExt->win.s.interruptLevel, /* Interrupt level. */ 230 pDevExt->win.s.interruptMode, /* LevelSensitive or Latched. */ 231 TRUE, /* Shareable interrupt. */ 232 pDevExt->win.s.interruptAffinity, /* CPU affinity. */ 233 FALSE); /* Don't save FPU stack. */ 234 if (NT_ERROR(rc)) 235 Log(("VBoxGuest::vboxguestwinGuestPnp: START_DEVICE: Could not connect interrupt, rc = 0x%x\n", rc)); 236 } 172 rc = vboxguestwinInit(pDevObj, pIrp); 237 173 } 238 174 } 239 175 240 if (NT_SUCCESS(rc)) 241 { 242 #ifdef VBOX_WITH_HGCM 243 /* Initialize the HGCM event notification semaphore. */ 244 KeInitializeEvent(&pDevExt->win.s.hgcm.s.keventNotification, NotificationEvent, FALSE); 245 246 /* Preallocated constant timeout 250ms for HGCM async waiter. */ 247 pDevExt->win.s.hgcm.s.WaitTimeout.QuadPart = 250; 248 pDevExt->win.s.hgcm.s.WaitTimeout.QuadPart *= -10000; /* Relative in 100ns units. */ 249 250 int vrc = VBoxGuestCreateKernelSession(pDevExt, &pDevExt->win.s.pKernelSession); 251 if (RT_FAILURE(vrc)) 252 Log(("VBoxGuest::vboxguestwinGuestPnp: START_DEVICE: Failed to allocated kernel session data! rc = %Rrc\n", rc)); 253 #endif 254 255 /* Ready to rumble! */ 256 Log(("VBoxGuest::vboxguestwinGuestPnp: START_DEVICE: Device is ready!\n")); 257 pDevExt->win.s.devState = WORKING; 258 } 259 else 176 if (NT_ERROR(rc)) 260 177 { 261 178 Log(("VBoxGuest::vboxguestwinGuestPnp: START_DEVICE: Error: rc = 0x%x\n", rc)); … … 304 221 if (pDevExt->win.s.devState == PENDINGREMOVE) 305 222 { 306 rc = vboxguestwinCleanup(pDevObj , pIrp);223 rc = vboxguestwinCleanup(pDevObj); 307 224 if (NT_SUCCESS(rc)) 308 225 { … … 377 294 if (pDevExt->win.s.devState == PENDINGSTOP) 378 295 { 379 rc = vboxguestwinCleanup(pDevObj , pIrp);296 rc = vboxguestwinCleanup(pDevObj); 380 297 if (NT_SUCCESS(rc)) 381 298 { … … 406 323 Log(("VBoxGuest::vboxguestwinGuestPnp: Returning with rc = 0x%x\n", rc)); 407 324 return rc; 408 }409 410 411 /**412 * Debug helper to dump a device resource list.413 *414 * @param pResourceList list of device resources.415 */416 static VOID vboxguestwinShowDeviceResources(PCM_PARTIAL_RESOURCE_LIST pResourceList)417 {418 #ifdef LOG_ENABLED419 PCM_PARTIAL_RESOURCE_DESCRIPTOR resource = pResourceList->PartialDescriptors;420 ULONG nres = pResourceList->Count;421 ULONG i;422 423 for (i = 0; i < nres; ++i, ++resource)424 {425 ULONG uType = resource->Type;426 static char* aszName[] =427 {428 "CmResourceTypeNull",429 "CmResourceTypePort",430 "CmResourceTypeInterrupt",431 "CmResourceTypeMemory",432 "CmResourceTypeDma",433 "CmResourceTypeDeviceSpecific",434 "CmResourceTypeBusNumber",435 "CmResourceTypeDevicePrivate",436 "CmResourceTypeAssignedResource",437 "CmResourceTypeSubAllocateFrom",438 };439 440 Log(("VBoxGuest::vboxguestwinShowDeviceResources: Type %s",441 uType < (sizeof(aszName) / sizeof(aszName[0]))442 ? aszName[uType] : "Unknown"));443 444 switch (uType)445 {446 case CmResourceTypePort:447 case CmResourceTypeMemory:448 Log(("VBoxGuest::vboxguestwinShowDeviceResources: Start %8X%8.8lX length %X\n",449 resource->u.Port.Start.HighPart, resource->u.Port.Start.LowPart,450 resource->u.Port.Length));451 break;452 453 case CmResourceTypeInterrupt:454 Log(("VBoxGuest::vboxguestwinShowDeviceResources: Level %X, Vector %X, Affinity %X\n",455 resource->u.Interrupt.Level, resource->u.Interrupt.Vector,456 resource->u.Interrupt.Affinity));457 break;458 459 case CmResourceTypeDma:460 Log(("VBoxGuest::vboxguestwinShowDeviceResources: Channel %d, Port %X\n",461 resource->u.Dma.Channel, resource->u.Dma.Port));462 break;463 464 default:465 Log(("\n"));466 break;467 }468 }469 #endif470 325 } 471 326 … … 591 446 592 447 /* Cleanup. */ 593 vboxguestwinCleanup(pDevObj , pIrp);448 vboxguestwinCleanup(pDevObj); 594 449 break; 595 450 } -
trunk/src/VBox/Additions/common/VBoxGuest/VBoxGuest-win.cpp
r32317 r32322 171 171 pDrvObj->MajorFunction[IRP_MJ_WRITE] = vboxguestwinNotSupportedStub; 172 172 #ifdef TARGET_NT4 173 rc = vboxguestwin NT4CreateDevice(pDrvObj, NULL /* pDevObj */, pRegPath);173 rc = vboxguestwinnt4CreateDevice(pDrvObj, NULL /* pDevObj */, pRegPath); 174 174 #else 175 175 pDrvObj->MajorFunction[IRP_MJ_PNP] = vboxguestwinPnP; … … 274 274 275 275 /** 276 * Debug helper to dump a device resource list. 277 * 278 * @param pResourceList list of device resources. 279 */ 280 static VOID vboxguestwinShowDeviceResources(PCM_PARTIAL_RESOURCE_LIST pResourceList) 281 { 282 #ifdef LOG_ENABLED 283 PCM_PARTIAL_RESOURCE_DESCRIPTOR resource = pResourceList->PartialDescriptors; 284 ULONG nres = pResourceList->Count; 285 ULONG i; 286 287 for (i = 0; i < nres; ++i, ++resource) 288 { 289 ULONG uType = resource->Type; 290 static char* aszName[] = 291 { 292 "CmResourceTypeNull", 293 "CmResourceTypePort", 294 "CmResourceTypeInterrupt", 295 "CmResourceTypeMemory", 296 "CmResourceTypeDma", 297 "CmResourceTypeDeviceSpecific", 298 "CmResourceTypeBusNumber", 299 "CmResourceTypeDevicePrivate", 300 "CmResourceTypeAssignedResource", 301 "CmResourceTypeSubAllocateFrom", 302 }; 303 304 Log(("VBoxGuest::vboxguestwinShowDeviceResources: Type %s", 305 uType < (sizeof(aszName) / sizeof(aszName[0])) 306 ? aszName[uType] : "Unknown")); 307 308 switch (uType) 309 { 310 case CmResourceTypePort: 311 case CmResourceTypeMemory: 312 Log(("VBoxGuest::vboxguestwinShowDeviceResources: Start %8X%8.8lX length %X\n", 313 resource->u.Port.Start.HighPart, resource->u.Port.Start.LowPart, 314 resource->u.Port.Length)); 315 break; 316 317 case CmResourceTypeInterrupt: 318 Log(("VBoxGuest::vboxguestwinShowDeviceResources: Level %X, Vector %X, Affinity %X\n", 319 resource->u.Interrupt.Level, resource->u.Interrupt.Vector, 320 resource->u.Interrupt.Affinity)); 321 break; 322 323 case CmResourceTypeDma: 324 Log(("VBoxGuest::vboxguestwinShowDeviceResources: Channel %d, Port %X\n", 325 resource->u.Dma.Channel, resource->u.Dma.Port)); 326 break; 327 328 default: 329 Log(("\n")); 330 break; 331 } 332 } 333 #endif 334 } 335 336 337 /** 338 * Global initialisation stuff (PnP + NT4 legacy). 339 * 340 * @param pDevObj Device object. 341 * @param pIrp Request packet. 342 */ 343 #ifndef TARGET_NT4 344 NTSTATUS vboxguestwinInit(PDEVICE_OBJECT pDevObj, PIRP pIrp) 345 #else 346 NTSTATUS vboxguestwinInit(PDRIVER_OBJECT pDrvObj, PDEVICE_OBJECT pDevObj, PUNICODE_STRING pRegPath) 347 #endif 348 { 349 PVBOXGUESTDEVEXT pDevExt = (PVBOXGUESTDEVEXT)pDevObj->DeviceExtension; 350 #ifndef TARGET_NT4 351 PIO_STACK_LOCATION pStack = IoGetCurrentIrpStackLocation(pIrp); 352 #endif 353 354 Log(("VBoxGuest::vboxguestwinInit\n")); 355 356 int rc = STATUS_SUCCESS; 357 #ifdef TARGET_NT4 358 /* 359 * Let's have a look at what our PCI adapter offers. 360 */ 361 Log(("VBoxGuest::vboxguestwinInit: Starting to scan PCI resources of VBoxGuest ...\n")); 362 363 /* Assign the PCI resources. */ 364 PCM_RESOURCE_LIST pResourceList = NULL; 365 UNICODE_STRING classNameString; 366 RtlInitUnicodeString(&classNameString, L"VBoxGuestAdapter"); 367 rc = HalAssignSlotResources(pRegPath, &classNameString, 368 pDrvObj, pDevObj, 369 PCIBus, pDevExt->win.s.busNumber, pDevExt->win.s.slotNumber, 370 &pResourceList); 371 if (pResourceList && pResourceList->Count > 0) 372 vboxguestwinShowDeviceResources(&pResourceList->List[0].PartialResourceList); 373 if (NT_SUCCESS(rc)) 374 rc = vboxguestwinScanPCIResourceList(pResourceList, pDevExt); 375 #else 376 if (pStack->Parameters.StartDevice.AllocatedResources->Count > 0) 377 vboxguestwinShowDeviceResources(&pStack->Parameters.StartDevice.AllocatedResources->List[0].PartialResourceList); 378 if (NT_SUCCESS(rc)) 379 rc = vboxguestwinScanPCIResourceList(pStack->Parameters.StartDevice.AllocatedResourcesTranslated, 380 pDevExt); 381 #endif 382 if (NT_SUCCESS(rc)) 383 { 384 /* 385 * Map physical address of VMMDev memory into MMIO region 386 * and init the common device extension bits. 387 */ 388 void *pvMMIOBase = NULL; 389 uint32_t cbMMIO = 0; 390 rc = vboxguestwinMapVMMDevMemory(pDevExt, 391 pDevExt->win.s.vmmDevPhysMemoryAddress, 392 pDevExt->win.s.vmmDevPhysMemoryLength, 393 &pvMMIOBase, 394 &cbMMIO); 395 if (NT_SUCCESS(rc)) 396 { 397 pDevExt->pVMMDevMemory = (VMMDevMemory *)pvMMIOBase; 398 399 Log(("VBoxGuest::vboxguestwinInit: pvMMIOBase = 0x%p, pDevExt = 0x%p, pDevExt->pVMMDevMemory = 0x%p\n", 400 pvMMIOBase, pDevExt, pDevExt ? pDevExt->pVMMDevMemory : NULL)); 401 402 int vrc = VBoxGuestInitDevExt(pDevExt, 403 pDevExt->IOPortBase, 404 pvMMIOBase, cbMMIO, 405 vboxguestwinVersionToOSType(g_winVersion), 406 VMMDEV_EVENT_MOUSE_POSITION_CHANGED); 407 if (RT_FAILURE(vrc)) 408 { 409 Log(("VBoxGuest::vboxguestwinInit: Could not init device extension, rc = %Rrc!\n", vrc)); 410 rc = STATUS_DEVICE_CONFIGURATION_ERROR; 411 } 412 } 413 else 414 Log(("VBoxGuest::vboxguestwinInit: Could not map physical address of VMMDev, rc = 0x%x!\n", rc)); 415 } 416 417 if (NT_SUCCESS(rc)) 418 { 419 int vrc = VbglGRAlloc((VMMDevRequestHeader **)&pDevExt->win.s.pPowerStateRequest, 420 sizeof (VMMDevPowerStateRequest), VMMDevReq_SetPowerStatus); 421 if (RT_FAILURE(vrc)) 422 { 423 Log(("VBoxGuest::vboxguestwinInit: Alloc for pPowerStateRequest failed, rc = %Rrc\n", vrc)); 424 rc = STATUS_UNSUCCESSFUL; 425 } 426 } 427 428 if (NT_SUCCESS(rc)) 429 { 430 /* 431 * Register DPC and ISR. 432 */ 433 Log(("VBoxGuest::vboxguestwinInit: Initializing DPC/ISR ...\n")); 434 435 IoInitializeDpcRequest(pDevExt->win.s.pDeviceObject, vboxguestwinDpcHandler); 436 #ifdef TARGET_NT4 437 /* Get an interrupt vector. */ 438 /* Only proceed if the device provides an interrupt. */ 439 if ( pDevExt->win.s.interruptLevel 440 || pDevExt->win.s.interruptVector) 441 { 442 pDevExt->win.s.interruptVector = HalGetInterruptVector(PCIBus, 443 pDevExt->win.s.busNumber, 444 pDevExt->win.s.interruptLevel, 445 pDevExt->win.s.interruptVector, 446 (PKIRQL)pDevExt->win.s.interruptLevel, 447 &pDevExt->win.s.interruptAffinity); 448 } 449 else 450 Log(("VBoxGuest::vboxguestwinInit: Device does not provide an interrupt!\n")); 451 #endif 452 if (pDevExt->win.s.interruptVector) 453 { 454 rc = IoConnectInterrupt(&pDevExt->win.s.pInterruptObject, /* Out: interrupt object. */ 455 (PKSERVICE_ROUTINE)vboxguestwinIsrHandler, /* Our ISR handler. */ 456 pDevExt, /* Device context. */ 457 NULL, /* Optional spinlock. */ 458 pDevExt->win.s.interruptVector, /* Interrupt vector. */ 459 (KIRQL)pDevExt->win.s.interruptLevel, /* Interrupt level. */ 460 (KIRQL)pDevExt->win.s.interruptLevel, /* Interrupt level. */ 461 pDevExt->win.s.interruptMode, /* LevelSensitive or Latched. */ 462 TRUE, /* Shareable interrupt. */ 463 pDevExt->win.s.interruptAffinity, /* CPU affinity. */ 464 FALSE); /* Don't save FPU stack. */ 465 if (NT_ERROR(rc)) 466 Log(("VBoxGuest::vboxguestwinInit: Could not connect interrupt, rc = 0x%x\n", rc)); 467 } 468 else 469 Log(("VBoxGuest::vboxguestwinInit: No interrupt vector found!\n")); 470 } 471 472 473 #ifdef VBOX_WITH_HGCM 474 /* Initialize the HGCM event notification semaphore. */ 475 KeInitializeEvent(&pDevExt->win.s.hgcm.s.keventNotification, NotificationEvent, FALSE); 476 477 /* Preallocated constant timeout 250ms for HGCM async waiter. */ 478 pDevExt->win.s.hgcm.s.WaitTimeout.QuadPart = 250; 479 pDevExt->win.s.hgcm.s.WaitTimeout.QuadPart *= -10000; /* Relative in 100ns units. */ 480 481 int vrc = VBoxGuestCreateKernelSession(pDevExt, &pDevExt->win.s.pKernelSession); 482 if (RT_FAILURE(vrc)) 483 { 484 Log(("VBoxGuest::vboxguestwinInit: Failed to allocated kernel session data! rc = %Rrc\n", rc)); 485 rc = STATUS_UNSUCCESSFUL; 486 } 487 #endif 488 489 if (RT_SUCCESS(rc)) 490 { 491 /* Ready to rumble! */ 492 Log(("VBoxGuest::vboxguestwinInit: Device is ready!\n")); 493 pDevExt->win.s.devState = WORKING; 494 } 495 496 Log(("VBoxGuest::vboxguestwinInit: Returned with rc = 0x%x\n", rc)); 497 return rc; 498 } 499 500 501 /** 276 502 * Cleans up all data (like device extension and guest mapping). 277 503 * 278 504 * @param pDrvObj Driver object. 279 * @param pIrp Request packet. 280 */ 281 NTSTATUS vboxguestwinCleanup(PDEVICE_OBJECT pDevObj, PIRP pIrp) 505 */ 506 NTSTATUS vboxguestwinCleanup(PDEVICE_OBJECT pDevObj) 282 507 { 283 508 Log(("VBoxGuest::vboxguestwinCleanup\n")); 284 509 285 NOREF(pIrp);286 510 PVBOXGUESTDEVEXT pDevExt = (PVBOXGUESTDEVEXT)pDevObj->DeviceExtension; 287 288 511 if (pDevExt) 289 512 { 513 #ifdef VBOX_WITH_GUEST_BUGCHECK_DETECTION 514 hlpDeregisterBugCheckCallback(pDevExt); /* ignore failure! */ 515 #endif 290 516 /* According to MSDN we have to unmap previously mapped memory. */ 291 517 vboxguestwinUnmapVMMDevMemory(pDevExt); … … 307 533 Log(("VBoxGuest::vboxguestwinGuestUnload\n")); 308 534 #ifdef TARGET_NT4 309 PVBOXGUESTDEVEXT pDevExt = (PVBOXGUESTDEVEXT)pDrvObj->DeviceObject->DeviceExtension; 310 unreserveHypervisorMemory(pDevExt); 311 312 hlpVBoxUnmapVMMDevMemory (pDevExt); 313 314 VBoxCleanupMemBalloon(pDevExt); 315 316 #ifdef VBOX_WITH_GUEST_BUGCHECK_DETECTION 317 hlpDeregisterBugCheckCallback(pDevExt); /* ignore failure! */ 318 #endif 319 535 vboxguestwinCleanup(pDrvObj->DeviceObject); 320 536 /* 321 537 * I don't think it's possible to unload a driver which processes have … … 508 724 /* Add at least one (bogus) fall through case to shut up MSVC! */ 509 725 case 0: 510 #endif511 512 #if 0513 #ifdef VBOX_WITH_MANAGEMENT514 case VBOXGUEST_IOCTL_CHECK_BALLOON:515 {516 VBoxGuestCheckBalloonInfo *pInfo = (VBoxGuestCheckBalloonInfo *)pBuf;517 518 if (pStack->Parameters.DeviceIoControl.OutputBufferLength != sizeof(VBoxGuestCheckBalloonInfo))519 {520 Log(("VBoxGuest::vboxguestwinGuestDeviceControl: OutputBufferLength %d != sizeof(ULONG) %d\n",521 pStack->Parameters.DeviceIoControl.OutputBufferLength, sizeof(VBoxGuestCheckBalloonInfo)));522 Status = STATUS_INVALID_PARAMETER;523 break;524 }525 526 ULONG cMemoryBalloonChunks;527 int rc = VBoxGuestQueryMemoryBalloon(pDevExt, &cMemoryBalloonChunks);528 if (RT_FAILURE(rc))529 {530 Log(("VBOXGUEST_IOCTL_CHECK_BALLOON: vbox rc = %Rrc\n", rc));531 Status = STATUS_UNSUCCESSFUL;532 }533 else534 {535 cbOut = pStack->Parameters.DeviceIoControl.OutputBufferLength;536 pInfo->cBalloonChunks = cMemoryBalloonChunks;537 pInfo->fHandleInR3 = false;538 }539 break;540 }541 #endif542 543 case VBOXGUEST_IOCTL_LOG(0): /* The size isn't relevant on NT. */544 {545 /* Enable this only for debugging:546 Log(("VBoxGuest::vboxguestwinGuestDeviceControl: VBOXGUEST_IOCTL_LOG %.*s\n", (int)pStack->Parameters.DeviceIoControl.InputBufferLength, pBuf));547 */548 LogRel(("%.*s", (int)pStack->Parameters.DeviceIoControl.InputBufferLength, pBuf));549 cbOut = 0;550 break;551 }552 726 #endif 553 727 default: -
trunk/src/VBox/Additions/common/VBoxGuest/VBoxGuest-win.h
r32317 r32322 174 174 175 175 RT_C_DECLS_BEGIN 176 NTSTATUS vboxguestwinCleanup(PDEVICE_OBJECT pDevObj, PIRP pIrp); 176 #ifdef TARGET_NT4 177 NTSTATUS vboxguestwinnt4CreateDevice(PDRIVER_OBJECT pDrvObj, PDEVICE_OBJECT pDevObj, PUNICODE_STRING pRegPath); 178 NTSTATUS vboxguestwinInit(PDRIVER_OBJECT pDrvObj, PDEVICE_OBJECT pDevObj, PUNICODE_STRING pRegPath); 179 #else 180 NTSTATUS vboxguestwinInit(PDEVICE_OBJECT pDevObj, PIRP pIrp); 181 #endif 182 NTSTATUS vboxguestwinCleanup(PDEVICE_OBJECT pDevObj); 177 183 NTSTATUS vboxguestwinPnP(PDEVICE_OBJECT pDevObj, PIRP pIrp); 178 184 VOID vboxguestwinDpcHandler(PKDPC pDPC, PDEVICE_OBJECT pDevObj, PIRP pIrp, PVOID pContext); … … 186 192 RT_C_DECLS_END 187 193 194 #ifdef TARGET_NT4 195 /* 196 * XP DDK #defines ExFreePool to ExFreePoolWithTag. The latter does not exist 197 * on NT4, so... The same for ExAllocatePool. 198 */ 199 #undef ExAllocatePool 200 #undef ExFreePool 201 #endif 202 188 203 #endif /* ___VBoxGuest_win_h */ 189 204
Note:
See TracChangeset
for help on using the changeset viewer.