NDK_FN_SEND função de retorno de chamada (ndkpi.h)
A função NdkSend (NDK_FN_SEND) posta uma solicitação de envio em um QP (par de filas NDK).
Sintaxe
NDK_FN_SEND NdkFnSend;
NTSTATUS NdkFnSend(
[in] NDK_QP *pNdkQp,
[in, optional] PVOID RequestContext,
const NDK_SGE *pSgl,
[in] ULONG nSge,
[in] ULONG Flags
)
{...}
Parâmetros
[in] pNdkQp
Um ponteiro para um objeto QP (par de filas NDK) (NDK_QP).
[in, optional] RequestContext
Um valor de contexto a ser retornado no RequestContext membro da estrutura de NDK_RESULT para essa solicitação.
pSgl
Uma matriz de estruturas SGE (NDK_SGE) que representam os buffers que contêm os dados a serem enviados.
[in] nSge
O número de estruturas SGE na matriz especificada no parâmetro pSgl.
[in] Flags
Um OR bit a bit de sinalizadores que especifica as operações permitidas. Há suporte para os seguintes sinalizadores:
Valor | Significado |
---|---|
|
Indica que a conclusão bem-sucedida dessa solicitação não gera um evento de conclusão na fila de conclusão de saída. No entanto, as solicitações que falham geram um evento na fila de conclusão. |
|
Indica que todas as solicitações de leitura anteriores devem ser concluídas antes que o hardware comece a processar essa solicitação. |
|
Indica que a fila de conclusão do par gera uma notificação. Para obter mais informações sobre NDK_OP_FLAG_SEND_AND_SOLICIT_EVENT, consulte a seção Comentários. |
|
Indica que a memória referenciada pelos SGEs deve ser transferida embutida. Além disso, o valor MemoryRegionToken nas entradas de NDK_SGE pode ser inválido. As solicitações embutidas não precisam limitar o número de entradas na lista SGE para o MaxInitiatorRequestSge valor especificado quando o par de filas foi criado. A quantidade de memória transferida embutida deve estar dentro dos limites de dados embutidos do par de filas. |
|
Indica ao provedor NDK que ele pode adiar a indicação da solicitação ao hardware para processamento. Para obter mais informações sobre esse sinalizador, consulte esquema de processamento adiado do NDKPI.
Observação Esse sinalizador tem suporte apenas no NDKPI 1.2 (Windows Server 2012 R2) e posterior. |
Valor de retorno
A função NdkSend retorna um dos seguintes códigos NTSTATUS.
Código de retorno | Descrição |
---|---|
|
A solicitação de envio foi postada com êxito. Uma entrada de conclusão será enfileirada na fila de conclusão (CQ) quando a solicitação de trabalho for concluída. |
|
O QP (par de filas) não está conectado. |
|
Ocorreu um erro. |
Observações
NdkSend posta uma solicitação de envio em um QP (par de fila).
Você pode usar o sinalizador NDK_OP_FLAG_SEND_AND_SOLICIT_EVENT se emitir várias solicitações de envio relacionadas. Defina esse sinalizador na última solicitação no grupo de solicitações de envio relacionadas.
Um consumidor do NDK pode usar esse sinalizador ao emitir várias solicitações de envio relacionadas. O consumidor do NDK define esse sinalizador apenas na última solicitação de envio relacionada. O par receberá todas as solicitações de envio normalmente. No entanto, quando o par recebe a última solicitação de envio (a solicitação com o sinalizador de NDK_OP_FLAG_SEND_AND_SOLICIT_EVENT definido), a fila de conclusão para o par gera uma notificação. A notificação é gerada após a conclusão da solicitação de recebimento. Esse sinalizador não tem significado para o receptor (par), a menos que o receptor tenha chamado anteriormente a função NdkArmCq (NDK_FN_ARM_CQ) com o tipo de notificação definido como NDK_CQ_NOTIFY_SOLICITED.
Requisitos
Requisito | Valor |
---|---|
de cliente com suporte mínimo | Nenhum com suporte, com suporte no NDIS 6.30 e posterior. |
servidor com suporte mínimo | Windows Server 2012 |
da Plataforma de Destino | Windows |
cabeçalho | ndkpi.h (inclua Ndkpi.h) |
IRQL | <=DISPATCH_LEVEL |
Consulte também
esquema de processamento adiado do NDKPI