EVT_WDF_INTERRUPT_ENABLE función de devolución de llamada (wdfinterrupt.h)
[Se aplica a KMDF y UMDF]
La evtInterruptEnable de un controlador función de devolución de llamada de eventos habilita una interrupción de hardware especificada.
Sintaxis
EVT_WDF_INTERRUPT_ENABLE EvtWdfInterruptEnable;
NTSTATUS EvtWdfInterruptEnable(
[in] WDFINTERRUPT Interrupt,
[in] WDFDEVICE AssociatedDevice
)
{...}
Parámetros
[in] Interrupt
Identificador de un objeto de interrupción del marco.
[in] AssociatedDevice
Identificador del objeto de dispositivo de marco que el controlador pasó a WdfInterruptCreate.
Valor devuelto
La función de devolución de llamada EvtInterruptEnable debe devolver STATUS_SUCCESS u otro valor de estado para el que NT_SUCCESS(estado) es igual a TRUE si la función no encuentra ningún error. De lo contrario, esta función debe devolver un valor de estado para el que NT_SUCCESS(estado) es igual a FALSE.
Observaciones
Para registrar una función de devolución de llamada EvtInterruptEnable, el controlador debe colocar la dirección de la función de devolución de llamada en una estructura de WDF_INTERRUPT_CONFIG antes de llamar a WdfInterruptCreate.
El marco llama a la evtInterruptEnable del controlador función de devolución de llamada cada vez que el dispositivo entra en su estado de trabajo (D0). Además, un controlador puede hacer que el marco llame a la función de devolución de llamada EvtInterruptEnable llamando a WdfInterruptEnable. Tenga en cuenta que la mayoría de los controladores basados en marcos no deben llamar a WdfInterruptEnable, ya que el marco llama al evtInterruptEnable del controlador función de devolución de llamada cada vez que el dispositivo entra en su estado de trabajo (D0).
Antes de llamar a la EvtInterruptEnable función de devolución de llamada, el marco genera irQL del procesador al DIRQL del dispositivo y adquiere el bloqueo de giro que el controlador especificó en la estructura WDF_INTERRUPT_CONFIG del objeto de interrupción.
A partir de la versión 1.11 de KMDF, el controlador puede proporcionar control de interrupciones de nivel pasivo. Si el controlador ha solicitado el control de interrupciones de nivel pasivo, antes de llamar a la función EvtInterruptEnable en IRQL = PASSIVE_LEVEL, el marco adquiere el bloqueo de interrupción de nivel pasivo que el controlador configuró en la estructura de WDF_INTERRUPT_CONFIG del objeto de interrupción.
Después de que la función de devolución de llamada EvtInterruptEnable evtDeviceD0EntryPostInterruptsEnabled función de devolución de llamada de eventos en IRQL = PASSIVE_LEVEL.
No debe suponer que un dispositivo usará los mismos recursos de interrupción cada vez que el marco llama a la EvtInterruptEnable de su controlador función de devolución de llamada. A veces, el administrador de PnP redistribuye los recursos del sistemay podría asignar nuevos recursos de interrupción al dispositivo. El controlador puede llamar a WdfInterruptGetInfo para determinar los recursos de interrupción de un dispositivo.
Para obtener más información sobre el control de interrupciones en controladores basados en marcos, consulte control de interrupciones de hardware.
Requisitos
Requisito | Valor |
---|---|
de la plataforma de destino de | Universal |
versión mínima de KMDF | 1.0 |
versión mínima de UMDF | 2.0 |
encabezado | wdfinterrupt.h (incluya Wdf.h) |
irQL | (Consulte la sección Comentarios). |