Compartir a través de


Macro WriteStructToMode (usermode_accessors.h)

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

Syntax

void WriteStructToMode(
  Destination,
  Source,
  Mode
);

Parameters

Destination

[out] Puntero a la ubicación de memoria donde se escribirá la estructura.

Source

[in] Puntero a la estructura que se va a escribir en la ubicación de memoria de destino.

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 destino apunta a la memoria en modo kernel. La macro realiza una escritura en la dirección especificada con memory_order_relaxed semántica. Consulte Comentarios para obtener más información.
UserMode El destino apunta a la memoria en modo de usuario. La macro genera una excepción si Destination no apunta a la memoria en modo de usuario; de lo contrario, realiza una escritura en 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 escribir una estructura en 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 destino 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

WriteStructToModeHelper

WriteStructToUser

ReadStructFromMode