Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
La macro WriteStructToModeAligned escribe de forma segura una estructura en la memoria en función del modo de procesador especificado con validación de alineación.
Syntax
void WriteStructToModeAligned(
Destination,
Source,
Mode,
Alignment
);
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. |
Alignment
[in] Alineación necesaria para la dirección de destino, en bytes.
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 aplicación de alineación y memoria en modo de usuario. Garantiza que la dirección proporcionada sea válida y accesible en función del modo de procesador especificado y cumpla los requisitos de alineación especificados al acceder a la memoria en modo de usuario.
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 aplica la alineación comprobando que la dirección de destino cumple el requisito de alineación especificado al acceder a la memoria en modo de usuario. Esto ayuda a evitar penalizaciones de rendimiento y posibles errores de hardware que pueden producirse al acceder a estructuras de datos desalineadas.
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 o no cumple los requisitos de alineación.
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 |