HW_INITIALIZATION_DATA 구조체(storport.h)
Storport(HW_INITIALIZATION_DATA) 구조에는 각 미니포트 드라이버와 미니포트 드라이버가 관리하는 하드웨어에 특정한 정보가 포함됩니다.
통사론
typedef struct _HW_INITIALIZATION_DATA {
ULONG HwInitializationDataSize;
INTERFACE_TYPE AdapterInterfaceType;
PHW_INITIALIZE HwInitialize;
PHW_STARTIO HwStartIo;
PHW_INTERRUPT HwInterrupt;
PVOID HwFindAdapter;
PHW_RESET_BUS HwResetBus;
PHW_DMA_STARTED HwDmaStarted;
PHW_ADAPTER_STATE HwAdapterState;
ULONG DeviceExtensionSize;
ULONG SpecificLuExtensionSize;
ULONG SrbExtensionSize;
ULONG NumberOfAccessRanges;
PVOID Reserved;
UCHAR MapBuffers;
BOOLEAN NeedPhysicalAddresses;
BOOLEAN TaggedQueuing;
BOOLEAN AutoRequestSense;
BOOLEAN MultipleRequestPerLu;
BOOLEAN ReceiveEvent;
USHORT VendorIdLength;
PVOID VendorId;
union {
USHORT ReservedUshort;
USHORT PortVersionFlags;
};
USHORT DeviceIdLength;
PVOID DeviceId;
PHW_ADAPTER_CONTROL HwAdapterControl;
PHW_BUILDIO HwBuildIo;
PHW_FREE_ADAPTER_RESOURCES HwFreeAdapterResources;
PHW_PROCESS_SERVICE_REQUEST HwProcessServiceRequest;
PHW_COMPLETE_SERVICE_IRP HwCompleteServiceIrp;
PHW_INITIALIZE_TRACING HwInitializeTracing;
PHW_CLEANUP_TRACING HwCleanupTracing;
PHW_TRACING_ENABLED HwTracingEnabled;
ULONG FeatureSupport;
ULONG SrbTypeFlags;
ULONG AddressTypeFlags;
ULONG Reserved1;
PHW_UNIT_CONTROL HwUnitControl;
} HW_INITIALIZATION_DATA, *PHW_INITIALIZATION_DATA;
회원
HwInitializationDataSize
sizeof(HW_INITIALIZATION_DATA)에서 반환한 대로 이 구조체의 크기를 바이트 단위로 지정합니다. 실제로 이 멤버는 미니포트 드라이버에서 사용 중인 이 구조체의 버전을 나타냅니다. 미니포트 드라이버의 DriverEntry 루틴은 포트 드라이버에 대해 이 멤버의 값을 설정해야 합니다.
AdapterInterfaceType
Storport 드라이버는 레거시 버스를 지원하지 않습니다. 따라서 SCSI 포트 드라이버와 함께 사용되는 대부분의 어댑터 인터페이스 형식은 Storport에 유효하지 않습니다. 특히 Isa, Eisa, MicroChannel및 TurboChannel 지원되지 않습니다. 또한 SCSI 포트 사례와 달리 Storport 드라이버와 함께 작동하는 미니포트 드라이버는 VendorIdLength, VendorId, DeviceIdLength및 DeviceId 멤버에 대한 값을 제공할 필요가 없습니다.
HwInitialize
모든 미니포트 드라이버에 필요한 진입점인 미니포트 드라이버의 HwStorInitialize 루틴에 대한 포인터입니다.
HwStartIo
모든 미니포트 드라이버에 필요한 진입점인 미니포트 드라이버의 HwStorStartIo 루틴에 대한 포인터입니다.
HwInterrupt
모든 미니포트 드라이버에 필요한 진입점인 미니포트 드라이버의 HwStorInterrupt 루틴에 대한 포인터입니다.
HwFindAdapter
모든 미니포트 드라이버에 필요한 진입점인 미니포트 드라이버의 HwStorFindAdapter 루틴에 대한 포인터입니다.
HwResetBus
모든 미니포트 드라이버에 필요한 진입점인 미니포트 드라이버의 HwStorResetBus 루틴에 대한 포인터입니다.
HwDmaStarted
Storport 드라이버는 하위 모드 DMA를 지원하지 않습니다. 따라서 이 멤버는 NULL
HwAdapterState
Storport 드라이버는 레거시 드라이버를 지원하지 않습니다. 따라서 이 멤버는 NULL
DeviceExtensionSize
미니포트 드라이버가 어댑터별 디바이스 확장에 필요한 크기(바이트)를 지정합니다. 미니포트 드라이버는 디바이스 확장을 드라이버 결정 HBA(호스트 버스 어댑터) 정보에 대한 스토리지로 사용합니다. 운영 체제별 포트 드라이버는 먼저 확장을 할당하고 0으로 채울 때 각 디바이스 확장을 한 번 초기화합니다. 미니포트 드라이버에 대한 모든 호출에서 HBA 관련 디바이스 확장에 대한 포인터를 전달합니다. 지정된 크기에는 미니포트 드라이버 요청 논리 단위 스토리지가 포함되지 않습니다. 논리 단위별 스토리지의 크기는 이 항목의 뒷부분에 설명된 SpecificLuExtensionSize 필드를 통해 지정됩니다.
SCSIPort는 어댑터가 중지될 때마다 디바이스 확장을 다시 초기화하므로 HwScsiFindAdapter
SpecificLuExtensionSize
미니포트 드라이버가 논리 단위별 스토리지(있는 경우)에 필요한 크기(바이트)를 지정합니다. 미니포트 드라이버는 버스의 주변 장치에 대한 드라이버 결정 논리 단위 정보에 대한 스토리지로 LU 확장을 사용할 수 있습니다. Storport 드라이버는 할당하는 각 LU 확장을 0으로 초기화합니다. 미니포트 드라이버가 스토리지가 필요한 LU별 정보를 유지 관리하지 않는 경우 이 멤버를 0으로 설정합니다. 이 값은 컨트롤러가 실제로 지원할 수 있는 것과 관계없이 HBA가 32비트 주소를 받을 수 있다는 가정을 기반으로 합니다. 64비트 주소를 처리하기 위해 LUN 또는 SRB 확장에 추가 공간이 필요한 경우 StorPortGetUncachedExtension같은 루틴과 함께 사용하기 전에 이 값을 적절하게 조정해야 합니다.
SrbExtensionSize
미니포트 드라이버가 요청당 스토리지에 필요한 크기(있는 경우)를 바이트 단위로 지정합니다. 미니포트 드라이버는 특정 요청을 처리하는 데 필요한 데이터와 같이 드라이버 결정 요청 관련 정보에 대한 스토리지로 SRB 확장을 사용할 수 있습니다. Storport 드라이버는 SRB 확장을 초기화하지 않지만 미니포트 드라이버에 보내는 각 SRB에서 이 스토리지에 대한 포인터를 설정합니다. SRB 확장은 HBA 하드웨어에서 안전하게 액세스할 수 있습니다. Storport 드라이버와 함께 작동하는 미니포트 드라이버는 분산형/수집 목록을 지원해야 하며 SRB별 분산/수집 목록은 일반적으로 SRB 확장에 할당되므로 이 멤버는 거의 0이 아닙니다. 미니포트 드라이버가 스토리지가 필요한 SRB별 정보를 유지 관리하지 않는 경우 이 멤버를 0으로 설정합니다.
이 값은 컨트롤러가 실제로 지원할 수 있는 것과 관계없이 HBA가 32비트 주소를 받을 수 있다는 가정을 기반으로 합니다. 64비트 주소를 처리하기 위해 LUN 또는 SRB 확장에 추가 공간이 필요한 경우 StorPortGetUncachedExtension같은 루틴과 함께 사용하기 전에 이 값을 적절하게 조정해야 합니다.
NumberOfAccessRanges
어댑터에서 사용하는 액세스 범위 수를 지정합니다. 각각은 메모리 주소 또는 I/O 포트 주소의 범위입니다.
Reserved
시스템 사용을 위해 예약되었으며 미니포트 드라이버에서 사용할 수 없습니다.
MapBuffers
Storport 드라이버가 SRB 데이터 버퍼 주소를 시스템 가상 주소에 매핑하는지 여부를 나타냅니다. MapBuffers 멤버는 다음 값 중 하나를 가질 수 있습니다.
값 | 의미 |
---|---|
STOR_MAP_NO_BUFFERS (0) | SRB_FUNCTION_IO_CONTROL 및 SRB_FUNCTION_WMI 제외한 모든 SRB에 매핑하지 마세요. |
STOR_MAP_ALL_BUFFERS (1) | 되지 않는. 이 값은 STOR_MAP_NON_READ_WRITE_BUFFERS 것과 같은 효과를 미칩니다. |
STOR_MAP_NON_READ_WRITE_BUFFERS (2) | 읽기 또는 쓰기 요청을 제외한 모든 I/O에 대한 버퍼를 매핑합니다. |
STOR_MAP_ALL_BUFFERS_INCLUDING_READ_WRITE (3) | 읽기 및 쓰기 요청을 포함하여 모든 I/O에 대한 버퍼를 매핑합니다. 이 값은 Windows 8부터 유효합니다. |
NeedPhysicalAddresses
TRUE
TaggedQueuing
TRUE
AutoRequestSense
TRUE
MultipleRequestPerLu
TRUE
ReceiveEvent
Storport 드라이버는 이 멤버를 무시합니다.
VendorIdLength
Storport 드라이버와 함께 작동하는 미니포트 드라이버는 PnP를 지원해야 하므로 Storport 드라이버는 이 멤버를 무시합니다.
VendorId
Storport 드라이버와 함께 작동하는 미니포트 드라이버는 PnP를 지원해야 하므로 Storport 드라이버는 이 멤버를 무시합니다.
ReservedUshort
PortVersionFlags
지원되는 기능을 나타내는 플래그입니다.
DeviceIdLength
Storport 드라이버와 함께 작동하는 미니포트 드라이버는 PnP를 지원해야 하므로 Storport 드라이버는 이 멤버를 무시합니다.
DeviceId
Storport 드라이버와 함께 작동하는 미니포트 드라이버는 PnP를 지원해야 하므로 Storport 드라이버는 이 멤버를 무시합니다.
HwAdapterControl
미니포트 드라이버의 HwStorAdapterControl 루틴에 대한 포인터입니다. Storport 드라이버와 함께 작동하는 미니포트 드라이버에는 PnP 지원이 필요하기 때문에 이는 필수 루틴입니다.
HwBuildIo
포트 드라이버가 미니포트 드라이버의 HwStorStartIo 루틴을 호출하기 전에 동기화되지 않은 처리를 수행하도록 호출하는 선택적 HwStorBuildIo 루틴에 대한 포인터입니다. 이 콜백은 물리적 미니포트와 관련이 있으며 가상 미니포트를 통해 NULL로 설정해야 합니다.
HwFreeAdapterResources
가상 미니포트 드라이버의 HwStorFreeAdapterResources 루틴에 대한 포인터로, 모든 가상 미니포트 드라이버에 필요한 진입점입니다. 이 콜백은 가상 미니포트와 관련이 있으며 물리적 미니포트에 대한 NULL
이 콜백은 Windows 8에 추가됩니다. 이전 버전의 Windows용 가상 미니포트는 이 구조 대신 VIRTUAL_HW_INITIALIZATION_DATA 사용해야 합니다.
HwProcessServiceRequest
가상 미니포트 드라이버의 HwStorProcessServiceRequest 루틴에 대한 포인터입니다. 이 콜백은 가상 미니포트와 관련이 있으며 물리적 미니포트에 대한 NULL
이 콜백은 Windows 8에 추가됩니다. 이전 버전의 Windows용 가상 미니포트는 이 구조 대신 VIRTUAL_HW_INITIALIZATION_DATA 사용해야 합니다.
HwCompleteServiceIrp
가상 미니포트 드라이버의 HwStorCompleteServiceIrp 루틴에 대한 포인터입니다. 이 콜백은 가상 미니포트와 관련이 있으며 물리적 미니포트에 대한 NULL
이 콜백은 Windows 8에 추가됩니다. 이전 버전의 Windows용 가상 미니포트는 이 구조 대신 VIRTUAL_HW_INITIALIZATION_DATA 사용해야 합니다.
HwInitializeTracing
가상 미니포트 드라이버의 HwStorInitializeTracing 루틴에 대한 포인터입니다. 이 콜백은 가상 미니포트와 관련이 있으며 물리적 미니포트에 대한 NULL
이 콜백은 Windows 8에 추가됩니다. 이전 버전의 Windows용 가상 미니포트는 이 구조 대신 VIRTUAL_HW_INITIALIZATION_DATA 사용해야 합니다.
HwCleanupTracing
가상 미니포트 드라이버의 HwStorCleanupTracing 루틴에 대한 포인터입니다. 이 콜백은 가상 미니포트와 관련이 있으며 물리적 미니포트에 대한 NULL
이 콜백은 Windows 8에 추가됩니다. 이전 버전의 Windows용 가상 미니포트는 이 구조 대신 VIRTUAL_HW_INITIALIZATION_DATA 사용해야 합니다.
HwTracingEnabled
선택적 HwStorTracingEnabled에 대한 포인터는 포트 드라이버가 추적을 사용하도록 설정되었는지 여부를 미니포트에 알리기 위해 호출하는 루틴입니다.
FeatureSupport
미니포트에서 지원하는 기능을 나타내는 플래그입니다. FeatureSupport 다음 값의 조합으로 설정됩니다.
값 | 의미 |
---|---|
STOR_FEATURE_VIRTUAL_MINIPORT(0x00000001) | 가상 미니포트 드라이버입니다. |
STOR_FEATURE_ATA_PASS_THROUGH(0x00000002) | 미니포트는 ATA 통과를 지원합니다. |
STOR_FEATURE_FULL_PNP_DEVICE_CAPABILITIES(0x00000004) | 미니포트는 STOR_DEVICE_CAPABILITIES_EX 구조의 전체 설정을 제공합니다. |
STOR_FEATURE_DUMP_POINTERS(0x00000008) | 미니포트는 덤프 포인터 SRB를 지원합니다. |
STOR_FEATURE_DEVICE_NAME_NO_SUFFIX(0x00000010) | 미니포트 드라이버는 디바이스 식별 이름의 일부로 접미사 "SCSI 유형 디바이스"를 원하지 않습니다. |
STOR_FEATURE_DUMP_RESUME_CAPABLE(0x00000020) | 미니포트의 덤프 기능은 최대 절전 모드에서 다시 시작하기 위해 작동합니다. |
STOR_FEATURE_DEVICE_DESCRIPTOR_FROM_ATA_INFO_VPD(0x00000040) | Storport 드라이버는 INQUIRY 데이터 대신 ATA 정보 VPD 페이지에서 STORAGE_DEVICE_DESCRIPTOR 초기화합니다. |
STOR_FEATURE_EXTRA_IO_INFORMATION(0x00000080) | 미니포트 드라이버는 사용 가능한 경우 SRBEX에서 SRBEX_DATA_IO_INFO 원합니다. |
STOR_FEATURE_ADAPTER_CONTROL_PRE_FINDADAPTER(0x00000100) | 미니포트 드라이버는 HwFindAdapter를 받기 전에 Storport에서 AdapterControl 호출을 안전하게 처리할 수 있습니다. |
STOR_FEATURE_ADAPTER_NOT_REQUIRE_IO_PORT(0x00000200) | 미니포트 드라이버는 어댑터에 IO 포트 리소스가 필요하지 않습니다. |
STOR_FEATURE_DUMP_16_BYTE_ALIGNMENT(0x00000400) | 미니포트 드라이버는 HwDeviceExtension을 덤프 모드에서 16 바이트 정렬하려고 합니다. |
STOR_FEATURE_SET_ADAPTER_INTERFACE_TYPE(0x00000800) | 미니포트는 Storport가 어댑터 인터페이스 형식을 설정하려고 합니다. |
STOR_FEATURE_DUMP_INFO(0x00001000) | 미니포트 드라이버는 덤프 정보 SRB를 지원합니다. |
STOR_FEATURE_DMA_ALLOCATION_NO_BOUNDARY(0x00002000) | 미니포트 드라이버는 경계 없이 실제 메모리에 DMA를 할당하도록 지원합니다. |
STOR_FEATURE_SUPPORTS_NVME_ADAPTER(0x00004000) | 미니포트 드라이버는 NVMe 기반 스토리지 어댑터를 지원합니다. |
STOR_FEATURE_REPORT_INTERNAL_DATA(0x00008000) | 미니포트 드라이버는 내부 데이터 보고를 지원합니다. |
STOR_FEATURE_EARLY_DUMP(0x00010000) | 미니포트 드라이버는 초기 크래시 덤프 생성을 지원합니다. |
STOR_FEATURE_NVME_ICE(0x00020000) | 미니포트 드라이버는 NVMe ICE를 지원합니다. |
SrbTypeFlags
미니포트에서 지원하는 SRB 형식을 나타내는 플래그입니다. SrbTypeFlags 0 또는 다음 값의 조합으로 설정됩니다.
값 | 의미 |
---|---|
SRB_TYPE_FLAG_SCSI_REQUEST_BLOCK(0x1) | 미니포트는 표준 SRB를 사용합니다. |
SRB_TYPE_FLAG_STORAGE_REQUEST_BLOCK(0x2) | 미니포트는 확장된 SRB를 지원합니다. |
AddressTypeFlags
미니포트에서 지원하는 주소 체계입니다. 현재 하나의 주소 구성표만 지원되며 미니포트는 이 멤버를 ADDRESS_TYPE_FLAG_BTL8 설정해야 합니다.
값 | 의미 |
---|---|
ADDRESS_TYPE_FLAG_BTL8(0x1) | 버스, 대상 및 LUN(BTL) 8비트 주소 지정 |
Reserved1
예약됨, 0으로 설정
HwUnitControl
미니포트 드라이버의 HwStorUnitControl 루틴을 가리키는 포인터입니다. 포트 드라이버는 스토리지 장치 디바이스에 대한 제어 요청으로 이 루틴을 호출합니다.
발언
모든 Storport 미니포트 드라이버의 DriverEntry 루틴은 미니포트 드라이버가 처음 0이 되면 StorPortInitialize 호출한 다음 HW_INITIALIZATION_DATA멤버를 설정해야 합니다.
요구 사항
요구 | 값 |
---|---|
헤더 | storport.h(Storport.h 포함) |