Compartilhar via


KMESSAGE_SERVICE_ROUTINE função de retorno de chamada (wdm.h)

Uma rotina InterruptMessageService atende a uma interrupção sinalizada por mensagem.

Sintaxe

KMESSAGE_SERVICE_ROUTINE KmessageServiceRoutine;

BOOLEAN KmessageServiceRoutine(
  [in] _KINTERRUPT *Interrupt,
  [in] PVOID ServiceContext,
       ULONG MessageID
)
{...}

Parâmetros

[in] Interrupt

Um ponteiro para a estrutura KINTERRUPT para a interrupção. O driver recebeu esse ponteiro na chamada para a rotina IoConnectInterruptEx que registrou a rotina InterruptMessageService do driver.

[in] ServiceContext

O valor ServiceContext que o driver passou para IoConnectInterruptEx quando a rotina InterruptMessageService foi registrada.

MessageID

A ID da mensagem para a interrupção. Esse valor é o índice para a entrada da interrupção na matriz de membros MessageInfo na estrutura IO_INTERRUPT_MESSAGE_INFO que descreve as interrupções sinalizadas por mensagem do driver.

Retornar valor

A rotina InterruptMessageService retornará TRUE se a interrupção for tratada pela rotina InterruptMessageService . Caso contrário, retornará FALSE.

Comentários

Os drivers usam IoConnectInterruptEx para registrar uma rotina InterruptMessageService para lidar com as interrupções sinalizadas por mensagem. Posteriormente, um driver pode cancelar o registro da rotina chamando IoDisconnectInterruptEx. Há suporte para interrupções sinalizadas por mensagem a partir do Windows Vista.

O sistema pode chamar uma rotina InterruptMessageService mesmo quando a interrupção da rotina não ocorreu. Por exemplo, se uma interrupção sinalizada por mensagem for compartilhada, InterruptMessageService poderá ser chamado para interrupções pertencentes a outros dispositivos. A rotina deve marcar se o valor do parâmetro ServiceContext corresponde ao valor passado para IoConnectInterruptEx. Se o valor corresponder, InterruptMessageService manipulará a interrupção e retornará TRUE. Caso contrário, InterruptMessageService não manipula a interrupção e retorna FALSE.

Um driver que usa MSI (PCI 2.2) deve examinar o parâmetro MessageID para distinguir entre as diferentes mensagens geradas pelo dispositivo, pois todas elas compartilham o mesmo recurso de interrupção (e, portanto, o mesmo retorno de chamada InterruptMessageService> ).

Observe que, se o sistema receber várias interrupções idênticas em um intervalo de tempo curto, ele poderá combiná-las em uma única chamada para InterruptMessageService. A rotina deve ser gravada para lidar com várias interrupções idênticas em uma única chamada.

Interrupções sinalizadas por mensagem são semelhantes em comportamento a interrupções disparadas por borda. O dispositivo envia uma solicitação de interrupção, mas não recebe nenhuma confirmação de hardware de que a solicitação foi recebida.

Um InterruptMessageService é executado em um IRQL maior ou igual ao DIRQL (IRQL do dispositivo máximo) para cada interrupção dos identificadores de rotina.

Exemplos

Para definir uma rotina de retorno de chamada InterruptMessageService , primeiro você deve fornecer uma declaração de função que identifique o tipo de rotina de retorno de chamada que você está definindo. O Windows fornece um conjunto de tipos de função de retorno de chamada para drivers. Declarar uma função usando os tipos de função de retorno de chamada ajuda a 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 rotina de retorno de chamada InterruptMessageService chamada MyInterruptMessageService, use o tipo KMESSAGE_SERVICE_ROUTINE conforme mostrado neste exemplo de código:

KMESSAGE_SERVICE_ROUTINE MyInterruptMessageService;

Em seguida, implemente sua rotina de retorno de chamada da seguinte maneira:

_Use_decl_annotations_
BOOLEAN
  MyInterruptMessageService(
    struct _KINTERRUPT  *Interrupt,
    PVOID  ServiceContext,
    ULONG  MessageId 
    )
  {
      // Function body
  }

O tipo de função KMESSAGE_SERVICE_ROUTINE é definido no arquivo de cabeçalho Wdm.h. Para identificar erros com mais precisão ao executar as ferramentas de análise de código, adicione a Use_decl_annotations anotação à sua definição de função. A Use_decl_annotations anotação garante que as anotações aplicadas ao tipo de função KMESSAGE_SERVICE_ROUTINE 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 WDM. Para obter informações sobre Use_decl_annotations, consulte Anotando o comportamento da função.

Requisitos

Requisito Valor
Cliente mínimo com suporte Consulte a seção Observações.
Plataforma de Destino Área de Trabalho
Cabeçalho wdm.h (include Wdm.h, Ntddk.h, Ntifs.h)
IRQL Consulte a seção Observações.

Confira também

Usando descritores de recursos de interrupção

IO_INTERRUPT_MESSAGE_INFO

IoConnectInterruptEx

IoDisconnectInterruptEx