Compartilhar via


Função WriteLongPtrToMode (usermode_accessors.h)

The WriteLongPtrToMode function safely writes a LONG_PTR value to memory based on the specified processor mode.

Syntax

VOID WriteLongPtrToMode(
  LONG_PTR        *Destination,
  LONG_PTR        Value,
  KPROCESSOR_MODE Mode
);

Parameters

Destination

[out] Um ponteiro para o local da memória em que o valor LONG_PTR será gravado.

Value

[in] O valor LONG_PTR a ser gravado no local de memória de destino.

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 Destination points to kernel-mode memory. The function performs a write to the specified address with memory_order_relaxed semantics. Consulte Comentários para obter mais detalhes.
UserMode Destination points to user-mode memory. The function raises an exception if Destination doesn't point to user-mode memory; otherwise it performs a write to the specified address with memory_order_relaxed semantics. Consulte Comentários para obter mais detalhes.

Return value

None

Remarks

Essa função fornece uma maneira segura de gravar um valor LONG_PTR na memória, com verificações de segurança extras ao acessar a memória do modo de usuário. 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 destino 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

See also

WriteLongPtrToUser

ReadLongPtrFromMode