Compartilhar via


Função FsRtlAllocateAePushLock (ntifs.h)

FsRtlAllocateAePushLock aloca e inicializa um bloqueio de push de expansão automática.

Sintaxe

PVOID FsRtlAllocateAePushLock(
  [in] POOL_TYPE PoolType,
  [in] ULONG     Tag
);

Parâmetros

[in] PoolType

O tipo de memória do pool a ser alocada para o bloqueio de push de expansão automática. Consulte POOL_TYPE para obter uma descrição dos tipos de memória do pool disponíveis. Você pode modificar o valor PoolType por meio de ORing bit a bit com o sinalizador POOL_RAISE_IF_ALLOCATION_FAILURE. Esse sinalizador fará com que uma exceção seja gerada se a solicitação de alocação não puder ser atendida.

[in] Tag

A marca de pool a ser usada para a memória alocada. Especifique a marca de pool como um literal de caractere diferente de zero de um a quatro caracteres delimitado por aspas simples (por exemplo, 'Tag1'). A cadeia de caracteres geralmente é especificada em ordem inversa (por exemplo, '1gaT'). Cada caractere ASCII na marca deve ser um valor no intervalo 0x20 (espaço) para 0x7E (bloco). Cada caminho de código de alocação deve usar uma marca de pool exclusiva para ajudar os depuradores e verificadores a identificar o caminho do código.

Valor de retorno

FsRtlAllocateAePushLock retornará NULL se não houver memória suficiente no pool gratuito para atender à solicitação. Caso contrário, a rotina retornará um ponteiro para o bloqueio de push de expansão automática alocado e inicializado.

Observações

FsRtlAllocateAePushLock é usado para alocar memória do pool para um bloqueio de push de expansão automática. Consulte FSRTL_ADVANCED_FCB_HEADER para obter mais informações sobre bloqueios de push de expansão automática.

O sistema associa a marca de pool à memória alocada. Ferramentas de programação, como WinDbg, podem exibir a marca de pool associada a cada buffer alocado. Gflags, uma ferramenta incluída nas Ferramentas de Depuração para Windows, ativa um recurso do sistema que solicita alocação de de pool especial para uma marca de pool específica. poolmon, que está incluído no WDK, rastreia a memória por marca de pool.

O chamador de FsRtlAllocateAePushLock deve chamar posteriormente FsRtlFreeAePushLock para liberar o bloqueio de push de expansão automática alocado.

O sistema define automaticamente determinados objetos de evento padrão quando a quantidade de pool (paginada ou não paga) é alta ou baixa. Os drivers podem esperar que esses eventos ajustem o uso do pool. Para obter mais informações, consulte de objetos de evento padrão.

Requisitos

Requisito Valor
de cliente com suporte mínimo Windows 10, versão 20H2
cabeçalho ntifs.h
IRQL <= APC_LEVEL

Consulte também

FSRTL_ADVANCED_FCB_HEADER

FsRtlFreeAePushLock

FsRtlSetupAdvancedHeaderEx2