ScsiPortGetLogicalUnit 函数 (srb.h)
ScsiPortGetLogicalUnit 例程返回指向给定外设的微型端口驱动程序的每 LU 存储区域的指针。
语法
SCSIPORT_API PVOID ScsiPortGetLogicalUnit(
[in] PVOID HwDeviceExtension,
[in] UCHAR PathId,
[in] UCHAR TargetId,
[in] UCHAR Lun
);
参数
[in] HwDeviceExtension
指向硬件设备扩展的指针。 这是端口驱动程序代表微型端口驱动程序分配和初始化的每个 HBA 存储区域。 微型端口驱动程序通常在此扩展中存储特定于 HBA 的信息,例如 HBA 的状态和 HBA 的映射访问范围。 在微型端口驱动程序调用 ScsiPortInitialize 后,HBA 设备对象的 DeviceExtension-HwDeviceExtension> 成员中的微型端口驱动程序可以使用此区域。 端口驱动程序在删除设备时释放此内存。
[in] PathId
标识 SCSI 总线。
[in] TargetId
标识总线上的目标控制器或设备。
[in] Lun
标识目标设备的逻辑单元号。
返回值
ScsiPortGetLogicalUnit 返回指向微型端口驱动程序所请求逻辑单元的存储区域的指针。 如果特定于操作系统的端口驱动程序认为此逻辑单元不存在,则返回 NULL。
注解
如果微型端口驱动程序的 DriverEntry 例程在调用 ScsiPortInitialize 时为 HW_INITIALIZATION_DATA中的 LuExtensionSize 指定零,则 ScsiPortGetLogicalUnit 不相关。 否则,特定于操作系统的端口驱动程序以零分配和初始化一组指定大小的 LU 扩展,供微型端口驱动程序使用。
Per-LU 存储可用于存储与特定外围设备相关的数据,例如保存的数据指针。 若要访问此区域,当驱动程序维护有关任何特定外设的状态或当前操作的信息时,微型端口驱动程序会调用 ScsiPortGetLogicalUnit 。
如果没有针对该逻辑单元的活动请求,并且从未成功选择设备,则特定于操作系统的端口驱动程序可以将逻辑单元视为不存在。
要求
要求 | 值 |
---|---|
目标平台 | 桌面 |
标头 | srb.h (包括 Miniport.h、Scsi.h) |
Library | Scsiport.lib |