2013-11-28 15:47:18 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS Floppy Disk Controller Driver
|
|
|
|
* LICENSE: GNU GPLv2 only as published by the Free Software Foundation
|
|
|
|
* FILE: drivers/storage/fdc/fdc/pdo.c
|
|
|
|
* PURPOSE: Physical Device Object routines
|
|
|
|
* PROGRAMMERS: Eric Kohl
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES *******************************************************************/
|
|
|
|
|
|
|
|
#include "fdc.h"
|
|
|
|
|
2014-11-02 18:58:04 +00:00
|
|
|
#define NDEBUG
|
2014-02-03 10:45:04 +00:00
|
|
|
#include <debug.h>
|
|
|
|
|
2013-11-28 15:47:18 +00:00
|
|
|
/* FUNCTIONS ******************************************************************/
|
|
|
|
|
2013-11-30 10:07:50 +00:00
|
|
|
static
|
|
|
|
NTSTATUS
|
|
|
|
FdcPdoQueryCapabilities(
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
PIO_STACK_LOCATION IrpSp)
|
|
|
|
{
|
|
|
|
PPDO_DEVICE_EXTENSION DeviceExtension;
|
|
|
|
PDEVICE_CAPABILITIES DeviceCapabilities;
|
|
|
|
|
|
|
|
DPRINT("Called\n");
|
|
|
|
|
|
|
|
DeviceExtension = (PPDO_DEVICE_EXTENSION)DeviceObject->DeviceExtension;
|
|
|
|
DeviceCapabilities = IrpSp->Parameters.DeviceCapabilities.Capabilities;
|
|
|
|
|
|
|
|
if (DeviceCapabilities->Version != 1)
|
|
|
|
return STATUS_UNSUCCESSFUL;
|
|
|
|
|
|
|
|
DeviceCapabilities->UniqueID = FALSE;
|
|
|
|
DeviceCapabilities->Address = DeviceExtension->DriveInfo->PeripheralNumber;
|
|
|
|
|
|
|
|
return STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static
|
|
|
|
NTSTATUS
|
|
|
|
FdcPdoQueryId(
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIO_STACK_LOCATION IrpSp,
|
|
|
|
OUT ULONG_PTR *Information)
|
|
|
|
{
|
|
|
|
PPDO_DEVICE_EXTENSION DeviceExtension;
|
|
|
|
PUNICODE_STRING SourceString;
|
|
|
|
UNICODE_STRING String;
|
|
|
|
NTSTATUS Status;
|
|
|
|
|
|
|
|
DeviceExtension = (PPDO_DEVICE_EXTENSION)DeviceObject->DeviceExtension;
|
|
|
|
RtlInitUnicodeString(&String, NULL);
|
|
|
|
|
|
|
|
switch (IrpSp->Parameters.QueryId.IdType)
|
|
|
|
{
|
|
|
|
case BusQueryDeviceID:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MJ_PNP / IRP_MN_QUERY_ID / BusQueryDeviceID\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
SourceString = &DeviceExtension->DeviceId;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BusQueryHardwareIDs:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MJ_PNP / IRP_MN_QUERY_ID / BusQueryHardwareIDs\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
SourceString = &DeviceExtension->HardwareIds;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BusQueryCompatibleIDs:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MJ_PNP / IRP_MN_QUERY_ID / BusQueryCompatibleIDs\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
SourceString = &DeviceExtension->CompatibleIds;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BusQueryInstanceID:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MJ_PNP / IRP_MN_QUERY_ID / BusQueryInstanceID\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
SourceString = &DeviceExtension->InstanceId;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
DPRINT1("IRP_MJ_PNP / IRP_MN_QUERY_ID / unknown query id type 0x%lx\n",
|
|
|
|
IrpSp->Parameters.QueryId.IdType);
|
|
|
|
ASSERT(FALSE);
|
|
|
|
return STATUS_NOT_SUPPORTED;
|
|
|
|
}
|
|
|
|
|
|
|
|
Status = DuplicateUnicodeString(RTL_DUPLICATE_UNICODE_STRING_NULL_TERMINATE,
|
|
|
|
SourceString,
|
|
|
|
&String);
|
|
|
|
|
|
|
|
*Information = (ULONG_PTR)String.Buffer;
|
|
|
|
|
|
|
|
return Status;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-11-28 15:47:18 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
FdcPdoPnp(
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp)
|
|
|
|
{
|
2013-11-30 10:07:50 +00:00
|
|
|
PIO_STACK_LOCATION IrpSp;
|
|
|
|
ULONG_PTR Information = 0;
|
|
|
|
NTSTATUS Status;
|
|
|
|
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("FdcPdoPnp()\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
|
|
|
|
Status = Irp->IoStatus.Status;
|
|
|
|
|
|
|
|
IrpSp = IoGetCurrentIrpStackLocation(Irp);
|
|
|
|
|
|
|
|
switch (IrpSp->MinorFunction)
|
|
|
|
{
|
|
|
|
case IRP_MN_DEVICE_USAGE_NOTIFICATION:
|
|
|
|
DPRINT1("Unimplemented IRP_MN_DEVICE_USAGE_NOTIFICATION received\n");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_EJECT:
|
|
|
|
DPRINT1("Unimplemented IRP_MN_EJECT received\n");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_QUERY_BUS_INFORMATION:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_QUERY_BUS_INFORMATION received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_QUERY_CAPABILITIES:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_QUERY_CAPABILITIES received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
Status = FdcPdoQueryCapabilities(DeviceObject, IrpSp);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_QUERY_DEVICE_RELATIONS:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_QUERY_DEVICE_RELATIONS received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_QUERY_DEVICE_TEXT:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_QUERY_DEVICE_TEXT received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_QUERY_ID:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_QUERY_ID received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
Status = FdcPdoQueryId(DeviceObject, IrpSp, &Information);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_QUERY_PNP_DEVICE_STATE:
|
|
|
|
DPRINT1("Unimplemented IRP_MN_QUERY_ID received\n");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_QUERY_RESOURCE_REQUIREMENTS:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_QUERY_RESOURCE_REQUIREMENTS received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_QUERY_RESOURCES:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_QUERY_RESOURCES received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_SET_LOCK:
|
|
|
|
DPRINT1("Unimplemented IRP_MN_SET_LOCK received\n");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_START_DEVICE:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_START_DEVICE received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_QUERY_STOP_DEVICE:
|
|
|
|
case IRP_MN_CANCEL_STOP_DEVICE:
|
|
|
|
case IRP_MN_STOP_DEVICE:
|
|
|
|
case IRP_MN_QUERY_REMOVE_DEVICE:
|
|
|
|
case IRP_MN_CANCEL_REMOVE_DEVICE:
|
|
|
|
case IRP_MN_SURPRISE_REMOVAL:
|
|
|
|
Status = STATUS_SUCCESS;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_REMOVE_DEVICE:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_REMOVE_DEVICE received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case IRP_MN_FILTER_RESOURCE_REQUIREMENTS:
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("IRP_MN_FILTER_RESOURCE_REQUIREMENTS received\n");
|
2013-11-30 10:07:50 +00:00
|
|
|
/* Nothing to do */
|
|
|
|
Irp->IoStatus.Status = Status;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
DPRINT1("Unknown IOCTL 0x%lx\n", IrpSp->MinorFunction);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
Irp->IoStatus.Information = Information;
|
|
|
|
Irp->IoStatus.Status = Status;
|
|
|
|
IoCompleteRequest(Irp, IO_NO_INCREMENT);
|
|
|
|
|
2014-11-02 18:58:04 +00:00
|
|
|
DPRINT("Leaving. Status 0x%X\n", Status);
|
2013-11-30 10:07:50 +00:00
|
|
|
|
2013-11-28 15:47:18 +00:00
|
|
|
return Status;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* EOF */
|