Compartir a través de


Macro ReadStructFromMode (usermode_accessors.h)

La macro ReadStructFromMode lee de forma segura una estructura de la memoria en función del modo de procesador especificado.

Syntax

void ReadStructFromMode(
  Destination,
  Source,
  Mode
);

Parameters

Destination

[out] Puntero a la estructura que recibe los datos leídos de la memoria.

Source

[in] Puntero a la ubicación de memoria desde la que se va a leer la estructura.

Mode

[in] Modo de procesador que determina cómo se realiza el acceso a la memoria. El modo puede ser uno de los siguientes valores.

Value Meaning
KernelMode El origen apunta a la memoria en modo kernel. La macro realiza una lectura de la dirección especificada con memory_order_relaxed semántica. Consulte Comentarios para obtener más información.
UserMode El origen apunta a la memoria en modo de usuario. La macro genera una excepción si Source no apunta a la memoria en modo de usuario; de lo contrario, realiza una lectura de la dirección especificada con memory_order_relaxed semántica. Consulte Comentarios para obtener más información.

Return value

None

Remarks

Esta macro proporciona una manera segura de leer una estructura de la memoria, con comprobaciones de seguridad adicionales al acceder a la memoria en modo de usuario. Garantiza que la dirección proporcionada sea válida y accesible en función del modo de procesador especificado.

La macro valida que el punto de origen y destino sean tipos compatibles y determina automáticamente el tamaño de la estructura de la operación de copia.

Esta macro no aplica la alineación.

Genera una excepción estructurada si se produce un error en el acceso a la memoria, como cuando la dirección de origen no es válida o no es accesible para el modo de procesador especificado.

El compilador nunca optimizará esta macro ni creará accesos adicionales a esta ubicación de memoria antes de llamar a la macro o después de que se devuelva la macro (a menos que el código fuente realice explícitamente estos accesos). El acceso a la memoria se realiza con memory_order_relaxed semántica.

Esta macro funciona en todas las versiones de Windows, no solo en la más reciente. Debe consumir el WDK más reciente para obtener la declaración de macro del encabezado usermode_accessors.h . También necesita la biblioteca (umaccess.lib) del WDK más reciente. Sin embargo, el controlador resultante se ejecutará correctamente en versiones anteriores de Windows.

Requirements

Requirement Value
Cliente mínimo compatible See Remarks
Header usermode_accessors.h
Library umaccess.lib
IRQL Menor o igual que APC_LEVEL

See also

ReadStructFromModeHelper

ReadStructFromUser

WriteStructToMode