EVT_WDF_DEVICE_RELATIONS_QUERY função de retorno de chamada (wdfdevice.h)
[Aplica-se somente ao KMDF]
O retorno de chamada de evento EvtDeviceRelationsQuery de um driver relata alterações nas relações entre dispositivos compatíveis com o driver.
Sintaxe
EVT_WDF_DEVICE_RELATIONS_QUERY EvtWdfDeviceRelationsQuery;
void EvtWdfDeviceRelationsQuery(
[in] WDFDEVICE Device,
[in] DEVICE_RELATION_TYPE RelationType
)
{...}
Parâmetros
[in] Device
Um identificador para um objeto de dispositivo de estrutura.
[in] RelationType
Um valor de enumerador do tipo DEVICE_RELATION_TYPE. A enumeração DEVICE_RELATION_TYPE é definida em wdm.h.
Retornar valor
Nenhum
Comentários
Para registrar a função de retorno de chamada EvtDeviceRelationsQuery , um driver deve chamar WdfDeviceInitSetPnpPowerEventCallbacks.
A maioria dos drivers baseados em estrutura não precisa fornecer essa função de retorno de chamada.
Durante a inicialização do sistema, o gerenciador de Plug and Play enumera todos os dispositivos no sistema enviando uma solicitação IRP_MN_QUERY_DEVICE_RELATIONS para a pilha de driver. Se um driver baseado em estrutura tiver registrado uma função de retorno de chamada EvtDeviceRelationsQuery , a estrutura a chamará. O driver de função do barramento deve relatar todos os dispositivos filho anexados ao barramento.
Além disso, depois que a estrutura chama a rotina IoInvalidateDeviceRelations para relatar uma relação alterada entre os dispositivos no ônibus do motorista, o gerenciador de Plug and Play envia outra solicitação IRP_MN_QUERY_DEVICE_RELATIONS para a pilha de driver. Em seguida, a estrutura chama a função de retorno de chamada EvtDeviceRelationsQuery do driver para que o driver possa fornecer detalhes sobre a alteração.
O tipo de trabalho que um driver deve fazer depende do valor recebido para o parâmetro RelationType . O valor pode ser um dos seguintes:
BusRelations
-
A maioria dos drivers baseados em estrutura não relata relações de barramento em uma função de retorno de chamada EvtDeviceRelationsQuery. Em vez disso, os drivers seguem as diretrizes descritas em Enumerando os Dispositivos em um Barramento.
EjectionRelations
-
A maioria dos drivers baseados em estrutura não relata relações de ejeção em uma função de retorno de chamada EvtDeviceRelationsQuery. Em vez disso, o driver do barramento do dispositivo chama WdfPdoAddEjectionRelationsPhysicalDevice e WdfPdoRemoveEjectionRelationsPhysicalDevice.
RemovalRelations
-
A maioria dos drivers baseados em estrutura não relata relações de remoção em uma função de retorno de chamada EvtDeviceRelationsQuery. Em vez disso, os drivers chamam WdfDeviceAddRemovalRelationsPhysicalDevice e WdfDeviceRemoveRemovalRelationsPhysicalDevice.
TargetDeviceRelation
-
Os drivers baseados em estrutura não precisam relatar a relação de destino de um dispositivo. Em vez disso, a estrutura manipula essa solicitação.
A estrutura pode chamar a função de retorno de chamada EvtDeviceRelationsQuery com um valor RelationType de EjectionRelations ou RemovalRelations mesmo se o dispositivo estiver sendo removido.
Requisitos
Requisito | Valor |
---|---|
Plataforma de Destino | Universal |
Versão mínima do KMDF | 1.0 |
Cabeçalho | wdfdevice.h (inclua Wdf.h) |
IRQL | PASSIVE_LEVEL |