ScsiPortGetLogicalUnit 函数 (srb.h)

ScsiPortGetLogicalUnit 例程返回指向给定外设的微型端口驱动程序的每 LU 存储区域的指针。

注意 SCSI 端口驱动程序和 SCSI 微型端口驱动程序模型将来可能会更改或不可用。 建议改用 Storport 驱动程序Storport 微型端口 驱动程序模型。
 

语法

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

另请参阅

SCSI 微型端口驱动程序的 DriverEntry

HW_INITIALIZATION_DATA (SCSI)

ScsiPortInitialize

ScsiPortMoveMemory