📄 usbls120.h
字号:
/*++
Copyright (c) 1999 Microsoft Corporation
Module Name:
usbls120.h
Abstract:
Kernel mode definitions and function prototypes
Environment:
Kernel mode
Notes:
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
PURPOSE.
Copyright (c) 1999 Microsoft Corporation. All Rights Reserved.
Revision History:
01/13/99: MRB Adapted from BULKUSB DDK sample.
--*/
#ifndef USBLS120_INCD
#define USBLS120_INCD
#include "usblsdbg.h"
#include <iopacket.h>
// We use a max transfer size of 64K
#define USBLS120_MAX_TRANSFER_SIZE 0x10000
// Flags to indicate if a device object is a FDO or a child PDO
#define DO_FDO 1
#define DO_PDO 2
#define max(a, b) (((a) > (b)) ? (a) : (b))
// Accept Device-Specific Command, as defined in USB Mass Storage CBI spec.
#define ADSC 0
// String definitions for our child PDO. These should be changed
// to be unique for your device to avoid name conflicts with
// other drivers based on this code.
#define CHILD_PDO_NAME L"\\Device\\USBLS1200"
#define CHILD_DEVICE_ID L"USBLS120\\DISK\0"
// IOS SGD structure from BLOCKDEV.H
typedef struct _BlockDev_Scatter_Gather
{
ULONG BD_SG_Count;
ULONG BD_SG_Buffer_Ptr;
} BlockDev_Scatter_Gather;
extern PDRIVER_OBJECT USBLS120DriverObject;
typedef void (_stdcall *COMPLETION_HANDLER)(PIOPACKET);
//
// A structure representing the instance information associated with
// this particular device.
//
typedef struct _DEVICE_EXTENSION {
// Device object we call when submitting Urbs
PDEVICE_OBJECT TopOfStackDeviceObject;
// The bus driver object
PDEVICE_OBJECT PhysicalDeviceObject;
DEVICE_POWER_STATE CurrentDevicePowerState;
// USB configuration handle and ptr for the configuration the
// device is currently in
USBD_CONFIGURATION_HANDLE UsbConfigurationHandle;
PUSB_CONFIGURATION_DESCRIPTOR UsbConfigurationDescriptor;
// ptr to the USB device descriptor
// for this device
PUSB_DEVICE_DESCRIPTOR UsbDeviceDescriptor;
// we support one interface
// this is a copy of the info structure
// returned from select_configuration or
// select_interface
PUSBD_INTERFACE_INFORMATION UsbInterface;
//Bus drivers set the appropriate values in this structure in response
//to an IRP_MN_QUERY_CAPABILITIES IRP. Function and filter drivers might
//alter the capabilities set by the bus driver.
DEVICE_CAPABILITIES DeviceCapabilities;
// used to save the currently-being-handled system-requested power irp request
PIRP PowerIrp;
// set when PendingIoCount goes to 0; flags device can be removed
KEVENT RemoveEvent;
// set when PendingIoCount goes to 1 ( 1st increment was on add device )
// this indicates no IO requests outstanding, either user or system
KEVENT NoPendingIoEvent;
// set to signal driver-generated power request is finished
KEVENT SelfRequestedPowerIrpEvent;
// spinlock used to protect inc/dec iocount logic
KSPIN_LOCK IoCountSpinLock;
// incremented when device is added and any IO request is received;
// decremented when any io request is completed or passed on, and when device is removed
ULONG PendingIoCount;
// count of open pipes
ULONG OpenPipeCount;
//flag set when processing IRP_MN_REMOVE_DEVICE
BOOLEAN DeviceRemoved;
// flag set when driver has answered success to IRP_MN_QUERY_REMOVE_DEVICE
BOOLEAN RemoveDeviceRequested;
// flag set when driver has answered success to IRP_MN_QUERY_STOP_DEVICE
BOOLEAN StopDeviceRequested;
// flag set when device has been successfully started
BOOLEAN DeviceStarted;
// flag set when IRP_MN_WAIT_WAKE is received and we're in a power state
// where we can signal a wait
BOOLEAN EnabledForWakeup;
// used to flag that we're currently handling a self-generated power request
BOOLEAN SelfPowerIrp;
// default power state to power down to on self-suspend
ULONG PowerDownLevel;
// default maximum transfer per irp size
ULONG MaximumTransferSize;
// Device object type (either FDO or child PDO)
ULONG DeviceObjectType;
// In data bulk pipe
ULONG DataInPipe;
// Out data bulk pipe
ULONG DataOutPipe;
// Status interrupt pipe
ULONG StatusPipe;
// Child PDO created to load the IOS port driver
PDEVICE_OBJECT ChildPdo;
// Completion handler registered by IOS port driver
COMPLETION_HANDLER CompleteRequest;
PURB StatusUrb;
PIOPACKET IoPacket;
PIRP Irp;
PURB Urb;
ULONG DataLeft;
ULONG CurrentSGD;
PWORK_QUEUE_ITEM WorkItem;
PRKDPC TransferDataDpc;
} DEVICE_EXTENSION, *PDEVICE_EXTENSION;
// function prototypes
NTSTATUS
USBLS120_ProcessPnPIrp(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
USBLS120_ProcessSysControlIrp(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
VOID
USBLS120_Unload(
IN PDRIVER_OBJECT DriverObject
);
NTSTATUS
USBLS120_StartDevice(
IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_StopDevice(
IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_RemoveDevice(
IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_CallUSBD(
IN PDEVICE_OBJECT DeviceObject,
IN PURB Urb
);
NTSTATUS
USBLS120_PnPAddDevice(
IN PDRIVER_OBJECT DriverObject,
IN PDEVICE_OBJECT PhysicalDeviceObject
);
NTSTATUS
USBLS120_CreateDeviceObject(
IN PDRIVER_OBJECT DriverObject,
IN PDEVICE_OBJECT PhysicalDeviceObject,
IN PDEVICE_OBJECT *DeviceObject
);
NTSTATUS
USBLS120_ConfigureDevice(
IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_IrpCompletionRoutine(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID Context
);
NTSTATUS
USBLS120_PoRequestCompletion(
IN PDEVICE_OBJECT DeviceObject,
IN UCHAR MinorFunction,
IN POWER_STATE PowerState,
IN PVOID Context,
IN PIO_STATUS_BLOCK IoStatus
);
NTSTATUS
USBLS120_PoSelfRequestCompletion(
IN PDEVICE_OBJECT DeviceObject,
IN UCHAR MinorFunction,
IN POWER_STATE PowerState,
IN PVOID Context,
IN PIO_STATUS_BLOCK IoStatus
);
PURB
USBLS120_BuildAsyncRequest(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PUSBD_PIPE_INFORMATION PipeHandle,
IN BOOLEAN Read
);
NTSTATUS
USBLS120_GetPortStatus(
IN PDEVICE_OBJECT DeviceObject,
IN PULONG PortStatus
);
NTSTATUS
USBLS120_ResetParentPort(
IN IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_SelfRequestPowerIrp(
IN PDEVICE_OBJECT DeviceObject,
IN POWER_STATE PowerState
);
BOOLEAN
USBLS120_SetDevicePowerState(
IN PDEVICE_OBJECT DeviceObject,
IN DEVICE_POWER_STATE DeviceState
);
NTSTATUS
USBLS120_AsyncReadWrite_Complete(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID Context
);
NTSTATUS
USBLS120_PowerIrp_Complete(
IN PDEVICE_OBJECT NullDeviceObject,
IN PIRP Irp,
IN PVOID Context
);
NTSTATUS
USBLS120_QueryCapabilities(
IN PDEVICE_OBJECT PdoDeviceObject,
IN PDEVICE_CAPABILITIES DeviceCapabilities
);
NTSTATUS
USBLS120_Write(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
USBLS120_Create(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
USBLS120_Read(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
USBLS120_AbortPipes(
IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_ProcessIOCTL(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
USBLS120_SelectInterface(
IN PDEVICE_OBJECT DeviceObject,
IN PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor
);
NTSTATUS
USBLS120_ResetDevice(
IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_Close(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
USBLS120_ResetPipe(
IN PDEVICE_OBJECT DeviceObject,
IN PUSBD_PIPE_INFORMATION PipeInfo
);
VOID
USBLS120_IncrementIoCount(
IN PDEVICE_OBJECT DeviceObject
);
LONG
USBLS120_DecrementIoCount(
IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_ProcessPowerIrp(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
USBLS120_SelfSuspendOrActivate(
IN PDEVICE_OBJECT DeviceObject,
IN BOOLEAN fSuspend
);
BOOLEAN
USBLS120_CancelPendingIo(
IN PDEVICE_OBJECT DeviceObject
);
BOOLEAN
USBLS120_CanAcceptIoRequests(
IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_QueryDeviceRelations(
IN PDEVICE_OBJECT pDeviceObject,
IN PIRP pIrp
);
NTSTATUS
USBLS120_FdoDeviceQuery(
IN PDEVICE_OBJECT pDeviceObject,
IN PIRP pIrp
);
NTSTATUS
USBLS120_PdoDeviceQuery(
IN PDEVICE_OBJECT pDeviceObject,
IN PIRP pIrp
);
NTSTATUS
USBLS120_PdoQueryID(
IN PDEVICE_OBJECT pDeviceObject,
IN PIRP pIrp
);
NTSTATUS
USBLS120_DispatchIrp(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
VOID
USBLS120_GetInquiryData(
PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_TransferCommandComplete(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID Reference
);
VOID
USBLS120_TransferDataDPC(
PKDPC Dpc,
PVOID DeferredContext,
PVOID SystemArgument1,
PVOID SystemArgument2
);
VOID
USBLS120_TransferData(
PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_TransferDataComplete(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID Reference
);
VOID
USBLS120_TransferDataWorker(
IN PVOID Parameter
);
VOID
USBLS120_TransferInterruptError(
IN PVOID Parameter
);
NTSTATUS
USBLS120_StartInterruptPipe(
IN PDEVICE_OBJECT DeviceObject
);
NTSTATUS
USBLS120_InterruptComplete(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID Reference
);
NTSTATUS
USBLS120_PdoProcessPnPIrp(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
USBLS120_QueryBusInfo(
IN PDEVICE_OBJECT pDeviceObject,
IN PIRP pIrp
);
NTSTATUS
USBLS120_PdoProcessPowerIrp(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
USBLS120_PdoSetPower(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
#endif // already included
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -