Compartir a través de


DRIVER_UNLOAD función de devolución de llamada (wdm.h)

La rutina Unload realiza las operaciones necesarias antes de que el sistema descargue el controlador.

Sintaxis

DRIVER_UNLOAD DriverUnload;

void DriverUnload(
  [in] _DRIVER_OBJECT *DriverObject
)
{...}

Parámetros

[in] DriverObject

Puntero proporcionado por el autor de la llamada a una estructura de DRIVER_OBJECT . Este es el objeto de controlador del controlador.

Valor devuelto

None

Observaciones

La rutina Unload de un controlador se ejecuta en un contexto de subproceso del sistema en IRQL = PASSIVE_LEVEL.

La rutina Unload es necesaria para los controladores WDM y opcional para los controladores que no son WDM. La rutina Unload de un controlador, si se proporciona, debe denominarse XxxUnload, donde Xxx es un prefijo específico del controlador. La rutina DriverEntry del controlador debe almacenar la dirección de la rutina Unload en DriverObject-DriverUnload>. (Si no se proporciona ninguna rutina, este puntero debe ser NULL).

Para obtener información detallada sobre cómo implementar la rutina Unload de un controlador, vea Escribir una rutina de descarga.

Ejemplos

Para definir una rutina de devolución de llamada Deload , primero debe proporcionar una declaración de función que identifique el tipo de rutina de devolución de llamada que está definiendo. Windows proporciona un conjunto de tipos de función de devolución de llamada para controladores. Declarar una función mediante los tipos de función de devolución de llamada ayuda a Code Analysis for Drivers, Static Driver Verifier (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 rutina de devolución de llamada Unload denominada MyUnload, use el tipo de DRIVER_UNLOAD como se muestra en este ejemplo de código:

DRIVER_UNLOAD MyUnload;

A continuación, implemente la rutina de devolución de llamada de la siguiente manera:

_Use_decl_annotations_
VOID 
  MyUnload(
    struct _DRIVER_OBJECT  *DriverObject
    )
  {
      // Function body
  }

El tipo de función DRIVER_UNLOAD se define en el archivo de encabezado Wdm.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 a la _Use_decl_annotations_ definición de la función. La _Use_decl_annotations_ anotación garantiza que se usen las anotaciones que se aplican al tipo de función DRIVER_UNLOAD en el archivo de encabezado. Para obtener más información sobre los requisitos de las declaraciones de función, vea Declarar funciones mediante tipos de roles de función para controladores WDM. Para obtener información sobre _Use_decl_annotations_, consulte Anotación del comportamiento de la función.

Requisitos

Requisito Value
Plataforma de destino Escritorio
Encabezado wdm.h (incluya Wdm.h, Ntddk.h, Ntifs.h)
IRQL Se llama en PASSIVE_LEVEL.