Função RtlLookupElementGenericTableAvl (ntddk.h)
A rotina RtlLookupElementGenericTableAvl pesquisa uma tabela genérica em busca de um elemento que corresponda aos dados especificados.
Sintaxe
NTSYSAPI PVOID RtlLookupElementGenericTableAvl(
[in] PRTL_AVL_TABLE Table,
[in] PVOID Buffer
);
Parâmetros
[in] Table
Ponteiro para a tabela genérica Adelson-Velsky/Landis (AVL) (RTL_AVL_TABLE). A tabela deve ter sido inicializada chamando RtlInitializeGenericTableAvl.
[in] Buffer
Um buffer de dados de pesquisa a ser passado para a CompareRoutine que foi registrada quando RtlInitializeGenericTableAvl inicializou a tabela genérica. Para obter mais informações, consulte a descrição de RtlInitializeGenericTableAvl.
Retornar valor
RtlLookupElementGenericTableAvl retorna um ponteiro para os dados do usuário associados ao elemento correspondente na tabela genérica ou NULL se a tabela genérica atualmente não tiver elementos ou se nenhum elemento correspondente for encontrado.
Comentários
Por padrão, o sistema operacional usa árvores de reprodução para implementar tabelas genéricas, mas a rotina RtlLookupElementGenericTableAvl só funciona com árvores Adelson-Velsky/Landis (AVL). Para configurar as rotinas de tabela genéricas para usar árvores AVL em vez de árvores de reprodução no driver, insira a seguinte instrução define em um arquivo de cabeçalho comum antes de incluir Ntddk.h:
#define RTL_USE_AVL_TABLES 0
Se RTL_USE_AVL_TABLES não estiver definido, você deverá usar a forma AVL das rotinas de tabela genéricas. Por exemplo, use a rotina RtlLookupElementGenericTableAvl em vez de RtlLookupElementGenericTable. Na chamada para RtlLookupElementGenericTableAvl, o chamador deve passar uma estrutura de tabela RTL_AVL_TABLE em vez de RTL_GENERIC_TABLE.
Chamadores do Rtl. As rotinas GenericTableAvl são responsáveis por sincronizar exclusivamente o acesso à tabela genérica. Um mutex rápido exclusivo é o mecanismo de sincronização mais eficiente a ser usado para essa finalidade.
Os chamadores de RtlLookupElementGenericTableAvl devem estar em execução no IRQL < DISPATCH_LEVEL se uma das seguintes condições for mantida:
A memória alocada pelo chamador na Tabela ou no Buffer é paginável.
A CompareRoutine fornecida pelo chamador contém código paginável.
Requisitos
Requisito | Valor |
---|---|
Plataforma de Destino | Universal |
Cabeçalho | ntddk.h (inclua Ntddk.h, Ntifs.h) |
Biblioteca | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL | DISPATCH_LEVEL IRQL < (consulte a seção Comentários) |