Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
The ReadUnicodeStringFromMode function safely reads a UNICODE_STRING structure from memory based on the specified processor mode.
Syntax
UNICODE_STRING ReadUnicodeStringFromMode(
const UNICODE_STRING *Source,
KPROCESSOR_MODE Mode
);
Parameters
Source
[in] A pointer to the memory location from which to read the UNICODE_STRING structure.
Mode
[in] O modo de processador que determina como o acesso à memória é executado. Mode can be one of the following values.
| Value | Meaning |
|---|---|
| KernelMode | Source points to kernel-mode memory. The function performs a read from the specified address with memory_order_relaxed semantics. Consulte Comentários para obter mais detalhes. |
| UserMode | Source points to user-mode memory. The function raises an exception if Source doesn't point to user-mode memory; otherwise it performs a read from the specified address with memory_order_relaxed semantics. Consulte Comentários para obter mais detalhes. |
Return value
ReadUnicodeStringFromMode returns the UNICODE_STRING structure read from the specified memory address.
Remarks
This function provides a safe way to read a UNICODE_STRING structure from memory, with extra safety checks when accessing user-mode memory. Ele garante que o endereço fornecido seja válido e acessível com base no modo de processador especificado.
Essa função não impõe alinhamento.
Ele gerará uma exceção estruturada se o acesso à memória falhar, como quando o endereço de origem estiver inacessível ou for inválido para o modo especificado.
Essa função nunca será otimizada pelo compilador, nem o compilador criará acessos adicionais a esse local de memória antes que a função seja chamada ou depois que a função retornar (a menos que o código-fonte execute explicitamente esses acessos). The memory access is performed with memory_order_relaxed semantics.
Essa função funciona em todas as versões do Windows, não apenas nas mais recentes. You need to consume the latest WDK to get the function declaration from the usermode_accessors.h header. You also need the library (umaccess.lib) from the latest WDK. No entanto, o driver resultante será executado bem em versões mais antigas do Windows.
Requirements
| Requirement | Value |
|---|---|
| Cliente mínimo suportado | See Remarks |
| Header | usermode_accessors.h |
| Library | umaccess.lib |
| IRQL | Menor ou igual a APC_LEVEL |