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 WriteStructToUserAligned escribe de forma segura una estructura en la memoria en modo de usuario con validación de alineación.
Syntax
void WriteStructToUserAligned(
Destination,
Source,
Alignment
);
Parameters
Destination
[out] Puntero a la ubicación de memoria en modo de usuario donde se escribirá la estructura.
Source
[in] Puntero a la estructura que se va a escribir en la ubicación de memoria de destino.
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 en modo de usuario con cumplimiento de alineación. Garantiza que la dirección proporcionada sea una dirección en modo de usuario y cumpla los requisitos de alineación especificados antes de escribir en ella.
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. 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 una dirección en modo de usuario, no es accesible 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 |