PROTOCOL_CO_OID_REQUEST_COMPLETE função de retorno de chamada (ndis.h)
A função ProtocolCoOidRequestComplete conclui o processamento de uma solicitação OID de CoNDIS assíncrona.
Sintaxe
PROTOCOL_CO_OID_REQUEST_COMPLETE ProtocolCoOidRequestComplete;
void ProtocolCoOidRequestComplete(
[in] NDIS_HANDLE ProtocolAfContext,
[in] NDIS_HANDLE ProtocolVcContext,
[in] NDIS_HANDLE ProtocolPartyContext,
[in, out] PNDIS_OID_REQUEST OidRequest,
[in] NDIS_STATUS Status
)
{...}
Parâmetros
[in] ProtocolAfContext
Um identificador que identifica uma área de contexto af (família de endereços). Se o driver for um cliente, ele forneceu esse identificador quando ele chamou o função NdisClOpenAddressFamilyEx para se conectar ao gerenciador de chamadas. Se o driver for um MCM (gerenciador de chamadas ou gerenciador de chamadas de miniporto), ele fornecerá esse identificador de sua função ProtocolCmOpenAf.
[in] ProtocolVcContext
Um identificador que identifica a VC (conexão virtual) ativa para a qual o driver solicitou ou definiu informações, se a solicitação foi específica de VC. Caso contrário, esse parâmetro será NULL.
[in] ProtocolPartyContext
Um identificador que identifica a parte em uma VC de vários pontos para a qual o driver solicitou ou definiu informações, se a solicitação for específica à parte. Caso contrário, esse parâmetro será NULL.
[in, out] OidRequest
Um ponteiro para a estrutura de NDIS_OID_REQUEST fornecida pelo driver que foi passada anteriormente para a função NdisCoOidRequest ou NdisMCmOidRequest.
[in] Status
O status final da solicitação. O driver de destino ou o NDIS determina esse status final. Esse parâmetro determina o que ProtocolCoOidRequestComplete faz com as informações em OidRequest.
Valor de retorno
Nenhum
Observações
O NDIS chama a função ProtocolCoOidRequestComplete para concluir o processamento da solicitação de cliente, gerenciador de chamadas ou MCM OID do CoNDIS para a qual a função NdisCoOidRequest ou função NdisMCmOidRequest retornada NDIS_STATUS_PENDING.
Para registrar ProtocolCoOidRequestComplete como cliente, um driver inicializa um NDIS_CO_CLIENT_OPTIONAL_HANDLERS estrutura e a passa no parâmetro OptionalHandlers da função NdisSetOptionalHandlers. Para registrar ProtocolCoOidRequestComplete como um gerenciador de chamadas, um driver inicializa um NDIS_CO_CALL_MANAGER_OPTIONAL_HANDLERS estrutura e a passa no parâmetro OptionalHandlers de NdisSetOptionalHandlers.
O driver de destino é o driver que acionou a solicitação de informações de OID. Uma chamada de driver de destino para o NdisMCoOidRequestComplete, NdisCoOidRequestCompleteou função NdisMCmOidRequestComplete fez com que o NDIS chamasse a função ProtocolCoOidRequestComplete. O NDIS encaminha o valor do parâmetro Status que foi passado para essas funções como o parâmetro status de de entrada para ProtocolCoOidRequestComplete.
ProtocolCoOidRequestComplete usa o valor de entrada de Status da seguinte maneira:
-
Se Status for NDIS_STATUS_SUCCESS, o bytesRead ou bytesWritten membro da estrutura NDIS_OID_REQUEST que o parâmetro OidRequest aponta para especificar a quantidade de informações transferidas do buffer no InformationBuffer do NDIS_OID_REQUEST para o driver de destino ou quantas informações foram retornadas no InformationBuffer, respectivamente.
Se o driver fez uma solicitação de consulta, ProtocolCoOidRequestComplete poderá usar os dados retornados em do InformationBuffer, conforme apropriado para o valor especificado no Oid membro do NDIS_OID_REQUEST.
-
Se Status for NDIS_STATUS_INVALID_LENGTH ou NDIS_STATUS_BUFFER_TOO_SHORT, o BytesNeeded membro da estrutura NDIS_OID_REQUEST que OidRequest aponta para especificar o valor específico da OID do membro InformationBufferLength do NDIS_OID_REQUEST necessário para realizar a operação solicitada.
Nestas circunstâncias, ProtocolCoOidRequestComplete pode alocar espaço de buffer suficiente para a solicitação, configurar outra estrutura NDIS_OID_REQUEST com o valor necessário para InformationBufferLength e tentar novamente a solicitação OID.
- Se Status for um valor NDIS_STATUS_ XXX que seja um erro irrecuperável, ProtocolCoOidRequestComplete deverá liberar a memória da estrutura NDIS_OID_REQUEST. ProtocolCoOidRequestComplete também deve determinar se o driver deve fechar a associação ou ajustar suas informações de estado específicas de associação para lidar com operações de E/S de rede contínuas na associação.
ProtocolCoOidRequestComplete pode ser chamado antes que o driver tenha tempo para inspecionar o código de status que NdisCoOidRequest ou NdisMCmOidRequest retorna.
Chamadas NDIS ProtocolCoOidRequestComplete no <do IRQL = DISPATCH_LEVEL.
exemplos de
Para definir uma função ProtocolCoOidRequestComplete, primeiro você deve fornecer uma declaração de função que identifique o tipo de função que você está definindo. O Windows fornece um conjunto de tipos de função para drivers. Declarar uma função usando os tipos de função ajuda Análise de Código para Drivers, SDV (Verificador de Driver Estático) e outras ferramentas de verificação a encontrar erros e é um requisito para gravar drivers para o sistema operacional Windows.Por exemplo, para definir uma função ProtocolCoOidRequestComplete chamada "MyCoOidRequestComplete", use o tipo PROTOCOL_CO_OID_REQUEST_COMPLETE conforme mostrado neste exemplo de código:
PROTOCOL_CO_OID_REQUEST_COMPLETE MyCoOidRequestComplete;
Em seguida, implemente sua função da seguinte maneira:
_Use_decl_annotations_
VOID
MyCoOidRequestComplete(
NDIS_HANDLE ProtocolAfContext,
NDIS_HANDLE ProtocolVcContext,
NDIS_HANDLE ProtocolPartyContext,
PNDIS_OID_REQUEST OidRequest,
NDIS_STATUS Status
)
{...}
O tipo de função PROTOCOL_CO_OID_REQUEST_COMPLETE é definido no arquivo de cabeçalho Ndis.h. Para identificar erros com mais precisão ao executar as ferramentas de análise de código, adicione a anotação Use_decl_annotations à sua definição de função. A anotação Use_decl_annotations garante que as anotações aplicadas ao tipo de função PROTOCOL_CO_OID_REQUEST_COMPLETE no arquivo de cabeçalho sejam usadas. Para obter mais informações sobre os requisitos para declarações de função, consulte Declarando funções usando tipos de função de função para drivers NDIS.
Para obter informações sobre Use_decl_annotations, consulte Anotando o comportamento da função.
Requisitos
Requisito | Valor |
---|---|
de cliente com suporte mínimo | Com suporte no NDIS 6.0 e posterior. |
da Plataforma de Destino | Windows |
cabeçalho | ndis.h (inclua Ndis.h) |
IRQL | <= DISPATCH_LEVEL (consulte a seção Comentários) |