NDK_FN_SEND回调函数 (ndkpi.h)
NdkSend (NDK_FN_SEND) 函数在 QP) (NDK 队列对上发布发送请求。
语法
NDK_FN_SEND NdkFnSend;
NTSTATUS NdkFnSend(
[in] NDK_QP *pNdkQp,
[in, optional] PVOID RequestContext,
const NDK_SGE *pSgl,
[in] ULONG nSge,
[in] ULONG Flags
)
{...}
参数
[in] pNdkQp
指向 NDK 队列对 (QP) 对象 (NDK_QP) 的指针。
[in, optional] RequestContext
要在此请求的 NDK_RESULT 结构的 RequestContext 成员中返回的上下文值。
pSgl
(NDK_SGE) 的 SGE 结构数组,这些) 表示存储要发送的数据的缓冲区。
[in] nSge
在 pSgl 参数中指定的数组中的 SGE 结构数。
[in] Flags
指定允许的操作的标志的按位 OR。 支持以下标志:
值 | 含义 |
---|---|
|
指示此请求的成功完成不会在出站完成队列中生成完成事件。 但是,失败的请求会在完成队列中生成事件。 |
|
指示在硬件开始处理此请求之前,所有以前的读取请求都必须完成。 |
|
指示对等方的完成队列生成通知。 有关 NDK_OP_FLAG_SEND_AND_SOLICIT_EVENT的详细信息,请参阅“备注”部分。 |
|
指示 SGE 引用的内存应以内联方式传输。 此外,NDK_SGE条目中的 MemoryRegionToken 值可能无效。 内联请求不需要将 SGE 列表中的条目数限制为创建队列对时指定的 MaxInitiatorRequestSge 值。 内联传输的内存量必须在队列对的内联数据限制内。 |
|
向 NDK 提供程序指示它可以延迟指示对硬件的请求进行处理。 有关此标志的详细信息,请参阅 NDKPI 延迟处理方案。
注意此标志仅在 NDKPI 1.2 (Windows Server 2012 R2) 及更高版本中受支持。 |
返回值
NdkSend 函数返回以下 NTSTATUS 代码之一。
返回代码 | 说明 |
---|---|
|
已成功发布发送请求。 完成工作请求后,完成项将排入完成队列 (CQ) 。 |
|
QP) (队列对未连接。 |
|
出现了错误。 |
注解
NdkSend 在 QP) (队列对上发布发送请求。
如果发出多个相关的发送请求,可以使用 NDK_OP_FLAG_SEND_AND_SOLICIT_EVENT 标志。 在相关发送请求组中的最后一个请求上设置此标志。
发出多个相关的发送请求时,NDK 使用者可以使用此标志。 NDK 使用者仅在最后一个相关的发送请求上设置此标志。 对等方将正常接收所有发送请求。 但是,当对等方收到最后一个发送请求 () 设置 NDK_OP_FLAG_SEND_AND_SOLICIT_EVENT 标志的请求时,该对等方的完成队列将生成通知。 通知在接收请求完成后生成。 此标志对接收方 (对等) 没有意义,除非接收方之前调用了 NdkArmCq (NDK_FN_ARM_CQ) 函数,并将通知类型设置为 NDK_CQ_NOTIFY_SOLICITED。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | 不支持,在 NDIS 6.30 及更高版本中受支持。 |
最低受支持的服务器 | Windows Server 2012 |
目标平台 | Windows |
标头 | ndkpi.h (包括 Ndkpi.h) |
IRQL | <=DISPATCH_LEVEL |