688{
694 WCHAR DeviceNameBuffer[
sizeof(
"\\Device\\Ide\\IdeDeviceP99999T9L9-FFF")];
697 static ULONG AtapPdoNumber = 0;
698
700
702 sizeof(DeviceNameBuffer),
703 PdoFormat,
704 ChanExt->DeviceObjectNumber,
705 AtaScsiAddress.TargetId,
706 AtaScsiAddress.Lun,
707 AtapPdoNumber++);
710
712 sizeof(*DevExt),
719 {
722 }
723
725
726
727 Pdo->AlignmentRequirement = ChanExt->Common.Self->AlignmentRequirement;
729
731
732 DevExt =
Pdo->DeviceExtension;
733
741
743 DevExt->
Device.TransportFlags = AtaScsiAddress.TargetId;
745
747 {
748
749 DevExt->
Device.DeviceSelect |= ((AtaScsiAddress.TargetId & 1) << 4);
750 }
751
753
756
759
762
763
765
768
773 goto Failure;
774
776 {
778
781 Request->Signature = ATA_DEVICE_REQUEST_SIGNATURE;
782#endif
783 }
784
791
792 return DevExt;
793
794Failure:
796
798}
struct _ATA_IO_CONTEXT_COMMON * PATA_IO_CONTEXT_COMMON
#define ATA_MIN_SECTOR_SIZE
256 sectors of 512 bytes (128 kB).
#define ATA_MIN_BUFFER_ALIGNMENT
VOID AtaPnpInitializeCommonExtension(_In_ PATAPORT_COMMON_EXTENSION CommonExt, _In_ PDEVICE_OBJECT SelfDeviceObject, _In_ ULONG Flags)
#define PORT_FLAG_PIO_FOR_LBA48_XFER
#define PORT_FLAG_PIO_VIA_DMA
#define DEVICE_IS_PDO_REMOVABLE
#define DECLARE_PAGED_WSTRING(v, n)
#define NUM_TO_BITMAP(num)
#define PORT_FLAG_IS_AHCI
#define DEVICE_PIO_FOR_LBA48_XFER
#define PORT_FLAG_IS_EXTERNAL
#define DEVICE_UNINITIALIZED
#define DEVICE_PIO_VIA_DMA
#define FILE_DEVICE_SECURE_OPEN
#define NT_SUCCESS(StatCode)
#define KeInitializeEvent(pEvt, foo, foo2)
#define InitializeListHead(ListHead)
#define KeInitializeSpinLock(sl)
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
#define FILE_DEVICE_MASS_STORAGE
static PVOID ExAllocatePoolZero(ULONG PoolType, SIZE_T NumberOfBytes, ULONG Tag)
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
NTSTATUS NTAPI IoCreateDevice(IN PDRIVER_OBJECT DriverObject, IN ULONG DeviceExtensionSize, IN PUNICODE_STRING DeviceName, IN DEVICE_TYPE DeviceType, IN ULONG DeviceCharacteristics, IN BOOLEAN Exclusive, OUT PDEVICE_OBJECT *DeviceObject)
NTSTRSAFEVAPI RtlStringCbPrintfW(_Out_writes_bytes_(cbDest) _Always_(_Post_z_) NTSTRSAFE_PWSTR pszDest, _In_ size_t cbDest, _In_ _Printf_format_string_ NTSTRSAFE_PCWSTR pszFormat,...)
VOID AtaPdoFreeDevice(_In_ PATAPORT_DEVICE_EXTENSION DevExt)
ATA_WORKER_DEVICE_CONTEXT Worker
LIST_ENTRY PowerIrpQueueList
ATAPORT_IO_CONTEXT Device
ULONG TransferModeAllowedMask
ATAPORT_COMMON_EXTENSION Common
PATAPORT_PORT_DATA PortData
LIST_ENTRY DeviceQueueList
PATA_DEVICE_REQUEST Requests
ATA_SCSI_ADDRESS AtaScsiAddress
PATA_IO_CONTEXT_COMMON Device
#define RtlZeroMemory(Destination, Length)
_Must_inspect_result_ _In_ PWDFDEVICE_INIT _In_opt_ PCUNICODE_STRING DeviceName
WDF_EXTERN_C_START typedef _Must_inspect_result_ _In_ WDFDRIVER _In_opt_ PWDF_OBJECT_ATTRIBUTES _In_ PDEVICE_OBJECT _In_opt_ PDEVICE_OBJECT _In_opt_ PDEVICE_OBJECT Pdo