mirror of
https://github.com/reactos/reactos.git
synced 2024-12-31 19:42:51 +00:00
[CDROM] Forcibly declare our CD devices to the MountMgr
This commit is contained in:
parent
2fb33d4c98
commit
0917815efa
2 changed files with 128 additions and 0 deletions
|
@ -731,6 +731,130 @@ Return Value:
|
||||||
RtlFreeUnicodeString(&unicodeString);
|
RtlFreeUnicodeString(&unicodeString);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
VOID
|
||||||
|
NTAPI
|
||||||
|
ReportToMountMgr(
|
||||||
|
IN PDEVICE_OBJECT CdDeviceObject
|
||||||
|
)
|
||||||
|
|
||||||
|
/*++
|
||||||
|
|
||||||
|
Routine Description:
|
||||||
|
|
||||||
|
This routine reports the creation of a cdrom device object to the
|
||||||
|
MountMgr to fake PnP.
|
||||||
|
|
||||||
|
Arguments:
|
||||||
|
|
||||||
|
CdDeviceObject - Pointer to the created cdrom device.
|
||||||
|
|
||||||
|
Return Value:
|
||||||
|
|
||||||
|
VOID
|
||||||
|
|
||||||
|
--*/
|
||||||
|
{
|
||||||
|
NTSTATUS status;
|
||||||
|
UNICODE_STRING mountMgrDevice;
|
||||||
|
PDEVICE_OBJECT deviceObject;
|
||||||
|
PFILE_OBJECT fileObject;
|
||||||
|
PMOUNTMGR_TARGET_NAME mountTarget;
|
||||||
|
ULONG cdLen;
|
||||||
|
PDEVICE_EXTENSION deviceExtension;
|
||||||
|
PIRP irp;
|
||||||
|
KEVENT event;
|
||||||
|
IO_STATUS_BLOCK ioStatus;
|
||||||
|
|
||||||
|
//
|
||||||
|
// First, get MountMgr DeviceObject.
|
||||||
|
//
|
||||||
|
|
||||||
|
RtlInitUnicodeString(&mountMgrDevice, MOUNTMGR_DEVICE_NAME);
|
||||||
|
status = IoGetDeviceObjectPointer(&mountMgrDevice, FILE_READ_ATTRIBUTES,
|
||||||
|
&fileObject, &deviceObject);
|
||||||
|
|
||||||
|
if (!NT_SUCCESS(status)) {
|
||||||
|
|
||||||
|
DebugPrint((1,
|
||||||
|
"ReportToMountMgr: Can't get MountMgr pointers %lx\n",
|
||||||
|
status));
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
deviceExtension = CdDeviceObject->DeviceExtension;
|
||||||
|
cdLen = deviceExtension->DeviceName.Length;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Allocate input buffer to report our partition device.
|
||||||
|
//
|
||||||
|
|
||||||
|
mountTarget = ExAllocatePool(NonPagedPool,
|
||||||
|
sizeof(MOUNTMGR_TARGET_NAME) + cdLen);
|
||||||
|
|
||||||
|
if (!mountTarget) {
|
||||||
|
|
||||||
|
DebugPrint((1,
|
||||||
|
"ReportToMountMgr: Allocation of mountTarget failed\n"));
|
||||||
|
|
||||||
|
ObDereferenceObject(fileObject);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mountTarget->DeviceNameLength = cdLen;
|
||||||
|
RtlCopyMemory(mountTarget->DeviceName, deviceExtension->DeviceName.Buffer, cdLen);
|
||||||
|
|
||||||
|
KeInitializeEvent(&event, NotificationEvent, FALSE);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Build the IRP used to communicate with the MountMgr.
|
||||||
|
//
|
||||||
|
|
||||||
|
irp = IoBuildDeviceIoControlRequest(IOCTL_MOUNTMGR_VOLUME_ARRIVAL_NOTIFICATION,
|
||||||
|
deviceObject,
|
||||||
|
mountTarget,
|
||||||
|
sizeof(MOUNTMGR_TARGET_NAME) + cdLen,
|
||||||
|
NULL,
|
||||||
|
0,
|
||||||
|
FALSE,
|
||||||
|
&event,
|
||||||
|
&ioStatus);
|
||||||
|
|
||||||
|
if (!irp) {
|
||||||
|
|
||||||
|
DebugPrint((1,
|
||||||
|
"ReportToMountMgr: Allocation of irp failed\n"));
|
||||||
|
|
||||||
|
ExFreePool(mountTarget);
|
||||||
|
ObDereferenceObject(fileObject);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Call the MountMgr.
|
||||||
|
//
|
||||||
|
|
||||||
|
status = IoCallDriver(deviceObject, irp);
|
||||||
|
|
||||||
|
if (status == STATUS_PENDING) {
|
||||||
|
KeWaitForSingleObject(&event, Suspended, KernelMode, FALSE, NULL);
|
||||||
|
status = ioStatus.Status;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// We're done.
|
||||||
|
//
|
||||||
|
|
||||||
|
DPRINT1("Reported to the MountMgr: %lx\n", status);
|
||||||
|
|
||||||
|
ExFreePool(mountTarget);
|
||||||
|
ObDereferenceObject(fileObject);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
NTSTATUS
|
NTSTATUS
|
||||||
NTAPI
|
NTAPI
|
||||||
CreateCdRomDeviceObject(
|
CreateCdRomDeviceObject(
|
||||||
|
@ -1323,6 +1447,8 @@ Return Value:
|
||||||
|
|
||||||
ExFreePool(buffer);
|
ExFreePool(buffer);
|
||||||
|
|
||||||
|
ReportToMountMgr(deviceObject);
|
||||||
|
|
||||||
//
|
//
|
||||||
// Start the timer now regardless of if Autorun is enabled.
|
// Start the timer now regardless of if Autorun is enabled.
|
||||||
// The timer must run forever since IoStopTimer faults.
|
// The timer must run forever since IoStopTimer faults.
|
||||||
|
|
|
@ -3,5 +3,7 @@
|
||||||
|
|
||||||
#include <ntdef.h>
|
#include <ntdef.h>
|
||||||
#include <ntstatus.h>
|
#include <ntstatus.h>
|
||||||
|
#include <mountmgr.h>
|
||||||
|
#include <mountdev.h>
|
||||||
|
|
||||||
#endif /* _CDROM_PCH_ */
|
#endif /* _CDROM_PCH_ */
|
||||||
|
|
Loading…
Reference in a new issue