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 ReadStructFromModeAligned lee de forma segura una estructura de la memoria basada en el modo de procesador especificado con validación de alineación.
Syntax
void ReadStructFromModeAligned(
Destination,
Source,
Mode,
Alignment
);
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. |
Alignment
[in] Alineación necesaria para la dirección de origen, en bytes.
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 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 origen 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 origen 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 |