Compartir a través de


MINIPORT_ISR función de devolución de llamada (ndis.h)

NDIS llama a la función MiniportInterrupt cuando una NIC u otro dispositivo que comparte la interrupción con la NIC, genera una interrupción.

Nota Debe declarar esta función mediante el tipo de MINIPORT_ISR. Para obtener más información, consulte la sección Ejemplos siguientes.
 

Sintaxis

MINIPORT_ISR MiniportIsr;

BOOLEAN MiniportIsr(
  [in]  NDIS_HANDLE MiniportInterruptContext,
  [out] PBOOLEAN QueueDefaultInterruptDpc,
  [out] PULONG TargetProcessors
)
{...}

Parámetros

[in] MiniportInterruptContext

Identificador de un bloque de información de contexto de interrupción. El controlador de minipuerto proporcionó este controlador en el parámetro MiniportInterruptContext que el controlador de miniporte pasó al función NdisMRegisterInterruptEx.

[out] QueueDefaultInterruptDpc

Puntero a una variable BOOLEAN que el controlador de miniporte establece antes de que vuelva de esta llamada. Un controlador de miniport establece este valor en TRUE para indicar que el controlador requiere un DPC en la CPU predeterminada (actual). Si este valor se establece en TRUE, NDIS omite el valor del parámetro TargetProcessors. Si se establece en FALSE, NDIS usa el valor del parámetro TargetProcessors para programar DPC. Si QueueDefaultInterruptDpc es TRUE, NDIS programará un DPC independientemente del valor devuelto de MiniportInterrupt.

[out] TargetProcessors

Máscara de bits que indica los procesadores de destino para los que NDIS debe programar un DPC. Esta máscara de bits representa los primeros 32 procesadores del grupo de procesadores 0. Cada bit de la máscara de bits identifica una CPU. Si el autor de la llamada establece el bit 0, NDIS programa un DPC para la CPU 0. Si el autor de la llamada establece el bit 1, NDIS programa un DPC para la CPU 1, etc. Si QueueDefaultInterruptDpc está establecido en FALSE y TargetProcessors está establecido en cero, NDIS no programará ningún DPC. De lo contrario, NDIS programará DPC independientemente del valor devuelto de MiniportInterrupt.

Nota controladores NDIS 6.20 y versiones posteriores no deben usar este parámetro para programar DPC. En su lugar, deben establecer este parámetro en cero y usar la función NdisMQueueDpcEx para programar DPC.
 

Valor devuelto

miniportInterrupt devuelve uno de los siguientes valores:

Código devuelto Descripción
TRUE

MiniportInterrupt determinó que la NIC subyacente generó la interrupción.

false

MiniportInterrupt determinó que la NIC subyacente no generaba la interrupción.

 
Nota NDIS pondrá en cola los DPC en función de los valores especificados en el QueueDefaultInterruptDpc y los parámetros targetProcessors independientemente del valor que miniportInterrupt devuelve. Sin embargo, miniportInterrupt todavía debe devolver el valor correcto.
 

Observaciones

Los controladores de miniport que registran una interrupción con la función NdisMRegisterInterruptEx deben proporcionar una función MiniportInterrupt.

Un controlador de miniport debe realizar el menor trabajo posible en su función MiniportInterrupt. Debe aplazar las operaciones de E/S para las interrupciones que genera la NIC en la función MiniportInterruptDPC.

Cuando se produce una interrupción en la línea de interrupción de una NIC, NDIS llama a la función miniportinterrupt del controlador de miniporte.

Todas las NIC pueden compartir interrupciones basadas en línea con otros dispositivos en el bus de E/S. Si la NIC no generó la interrupción, MiniportInterrupt debe devolver FALSE inmediatamente para que el sistema pueda llamar al controlador del dispositivo que generó la interrupción. Si el QueueDefaultInterruptDpc de está establecido en FALSE y el parámetro TargetProcessors está establecido en cero, NDIS no programará ningún DPC. De lo contrario, NDIS programará DPC independientemente de laMiniportInterruptvalor de turno de MiniportInterrupt.

Si la interrupción es para la NIC, MiniportInterrupt descarta la interrupción en la NIC, guarda el estado que debe tener sobre la interrupción y aplaza la mayor cantidad posible del procesamiento de E/S a la función MiniportInterruptDPC.

Si la NIC subyacente generó la interrupción especificada y el controlador de miniportar solicitará llamadas a procedimientos diferidos (DPC), el controlador de miniporte debe deshabilitar todas las interrupciones adicionales de la NIC y volver a habilitar las interrupciones una vez finalizadas todas las DPC.

El controlador de miniport debe establecer QueueDefaultInterruptDpc en TRUE para programar un DPC solo para la CPU predeterminada. El controlador podría hacerlo, por ejemplo, si:

  • La NIC generó la interrupción para indicar la finalización de una operación de envío o cualquier otra solicitud que no se ejecute en otras CPU.
  • La NIC generó la interrupción para indicar los datos recibidos y el controlador de miniporte no puede procesar paquetes recibidos en DPC independientes.
  • La interrupción indica los paquetes recibidos y el controlador de miniportar puede procesar paquetes recibidos en DPC independientes, pero escala lateral de recepción (RSS) no está habilitado para el controlador de miniport. Para obtener más información, consulte OID_GEN_RECEIVE_SCALE_CAPABILITIES y OID_GEN_RECEIVE_SCALE_PARAMETERS.
Si un controlador de miniporte procesa paquetes recibidos en DPC independientes, el controlador establece el parámetro QueueDefaultInterruptDpc en FALSE. El controlador de miniport debe establecer el TargetProcessors bit para la CPU asociada a cada cola de recepción no vacía. NDIS programará un DPC en cada una de las CPU indicadas.
Nota NDIS pondrá en cola los DPC en función de los valores especificados en el QueueDefaultInterruptDpc y los parámetros targetProcessors independientemente del valor que miniportInterrupt devuelve. Sin embargo, miniportInterrupt todavía debe devolver el valor correcto.
 
Si MiniportInterrupt recursos compartidos, como registros de NIC o variables de estado, con otra función MiniportXxx que se ejecuta en un IRQL inferior, esa función miniportXxx debe llamar a la función función NdisMSynchronizeWithInterruptEx. Esto garantiza que la función MiniportSynchronizeInterrup t del controlador acceda a los recursos compartidos de forma sincronizada y segura para varios procesadores.

Un controlador de minipuerto puede llamar al función NdisMDeregisterInterruptEx de su MiniportInitializeEx o función miniportHaltEx para liberar los recursos asignados con NdisMRegisterInterruptEx. Después de que NdisMDeregisterInterruptEx devuelve, NDIS no llama a la función MiniportInterrupt o MiniportInterruptDPC.

NDIS llama a miniportInterrupt en el DIRQL de la interrupción que el controlador de miniporte registró en una llamada anterior a NdisMRegisterInterruptEx. Por lo tanto, miniportInterrupt debe llamar al subconjunto de las funciones NDIS, como la NdisRawXxx o NdisRead/WriteRegisterxxx funciones, que son seguras para llamar a en cualquier IRQL.

Ejemplos de

Para definir una función MiniportInterrupt, primero debe proporcionar una declaración de función que identifique el tipo de función que va a definir. Windows proporciona un conjunto de tipos de función para controladores. Declarar una función mediante los tipos de función ayuda a análisis de código para controladores, comprobador de controladores estáticos (SDV) y otras herramientas de comprobación encuentran errores y es un requisito para escribir controladores para el sistema operativo Windows.

Por ejemplo, para definir una función MiniportInterrupt denominada "MyInterrupt", use el tipo MINIPORT_ISR tal como se muestra en este ejemplo de código:

MINIPORT_ISR MyInterrupt;

A continuación, implemente la función de la siguiente manera:

_Use_decl_annotations_
BOOLEAN
 MyInterrupt(
    NDIS_HANDLE  MiniportInterruptContext,
    PBOOLEAN  QueueDefaultInterruptDpc,
    PULONG  TargetProcessors
    )
  {...}

El tipo de función MINIPORT_ISR se define en el archivo de encabezado Ndis.h. Para identificar con más precisión los errores al ejecutar las herramientas de análisis de código, asegúrese de agregar la anotación Use_decl_annotations a la definición de función. La anotación Use_decl_annotations garantiza que se usen las anotaciones que se aplican al tipo de función MINIPORT_ISR en el archivo de encabezado. Para obtener más información sobre los requisitos de las declaraciones de función, vea Declaración de funciones mediante el uso de tipos de roles de función para controladores NDIS.

Para obtener información sobre Use_decl_annotations, vea Anotación del comportamiento de la función.

Requisitos

Requisito Valor
cliente mínimo admitido Se admite en NDIS 6.0 y versiones posteriores.
de la plataforma de destino de Windows
encabezado de ndis.h (incluya Ndis.h)
irQL Consulte la sección Comentarios.

Consulte también

MiniportHaltEx

MiniportInitializeEx

miniportInterruptDPC

MiniportSynchronizeInterrupt NDIS_MINIPORT_INTERRUPT_CHARACTERISTICS

NdisMDeregisterInterruptEx

NdisMQueueDpcEx

NdisMRegisterInterruptEx

NdisMSynchronizeWithInterruptEx OID_GEN_RECEIVE_SCALE_CAPABILITIES OID_GEN_RECEIVE_SCALE_PARAMETERS

de escalado lateral de recepción (RSS) de