OID_SRIOV_WRITE_VF_CONFIG_BLOCK
过分驱动程序发出对象标识符 (OID) OID_SRIOV_WRITE_VF_CONFIG_BLOCK集请求,以将数据写入 PCI Express (PCIe) Virtual Function (VF) 配置块。
过大驱动程序向网络适配器的 PCIe 物理功能 (PF) 的微型端口驱动程序发出此 OID 集请求。 支持单根 I/O 虚拟化 (SR-IOV) 接口的 PF 微型端口驱动程序需要此 OID 方法请求。
NDIS_OID_REQUEST 结构的 InformationBuffer 成员包含指向调用方分配的缓冲区的指针。 此缓冲区的格式设置为包含以下内容:
一个 NDIS_SRIOV_WRITE_VF_CONFIG_BLOCK_PARAMETERS 结构,其中包含从此结构的开头到包含写入 VF 配置块的数据的缓冲区内某个位置的偏移量(以字节为单位)。
用于将数据写入指定 VF 配置块的额外缓冲区空间。
注解
VF 配置块用于 PF 和 VF 微型端口驱动程序之间的反向通道通信。 IHV 可以为微型端口驱动程序定义一个或多个 VF 配置块。 每个 VF 配置块都有 IHV 定义的格式、长度和块 ID。
注意 每个 VF 配置块中的数据仅由 PF 和 VF 微型端口驱动程序使用。
在发出 OID_SRIOV_WRITE_VF_CONFIG_BLOCK 的 OID 集请求之前,过度覆盖驱动程序必须按以下方式设置 NDIS_SRIOV_WRITE_VF_CONFIG_BLOCK_PARAMETERS 结构的成员:
将 VFId 成员设置为要为其写入信息的 VF 的标识符。
将 BlockId 成员设置为要从中写入信息的配置块的标识符。
将 Length 成员设置为要写入 VF 配置块的字节数。
将 BufferOffset 成员设置为由 InformationBuffer 成员) 引用的缓冲区 (偏移量,该成员包含要从指定的 VF 配置块写入的数据。 此偏移量以 NDIS_SRIOV_WRITE_VF_CONFIG_BLOCK_PARAMETERS结构开头 的字节为单位指定。
处理 OID_SRIOV_WRITE_VF_CONFIG_BLOCK 的 OID 集请求时,PF 微型端口驱动程序必须遵循以下准则:
PF 微型端口驱动程序必须验证由 NDIS_SRIOV_WRITE_VF_CONFIG_BLOCK_PARAMETERS 结构的 VFId 成员指定的 VF 是否具有以前分配的资源。 PF 微型端口驱动程序在OID_NIC_SWITCH_ALLOCATE_VF的 OID 方法请求期间为 VF 分配资源。 如果尚未分配指定 VF 的资源,驱动程序必须使 OID 请求失败。
PF 微型端口驱动程序必须验证 NDIS_SRIOV_WRITE_VF_CONFIG_BLOCK_PARAMETERS 结构的 BlockId 成员是否指定了有效的 VF 配置块。 否则,驱动程序必须使 OID 请求失败。
有关单根 I/O 虚拟化 (SR-IOV) 接口中的反向通道通信的详细信息,请参阅 SR-IOV PF/VF 反向通道通信。
返回状态代码
微型端口驱动程序为 OID_SRIOV_WRITE_VF_CONFIG_BLOCK 的 OID 集请求返回以下状态代码之一:
状态代码 | 说明 |
---|---|
NDIS_STATUS_SUCCESS |
OID 请求已成功完成。 |
NDIS_STATUS_NOT_SUPPORTED |
微型端口驱动程序不支持单根 I/O 虚拟化 (SR-IOV) 接口,或者未启用该接口。 |
NDIS_STATUS_INVALID_PARAMETER |
NDIS_SRIOV_WRITE_VF_CONFIG_BLOCK_PARAMETERS 结构的一个或多个成员具有无效值。 |
NDIS_STATUS_INVALID_LENGTH |
信息缓冲区太短。 NDIS 设置数据。SET_INFORMATION。NDIS_OID_REQUEST结构中的 BytesNeeded 成员达到所需的最小缓冲区大小。 |
NDIS_STATUS_FAILURE |
由于其他原因,请求失败。 |
要求
版本 |
在 NDIS 6.30 及更高版本中受支持。 |
标头 |
Ntddndis.h (包括 Ndis.h) |