Função IoGetAttachedDeviceReference (wdm.h)

A rotina IoGetAttachedDeviceReference retorna um ponteiro para o objeto de dispositivo de nível mais alto em uma pilha de driver e incrementa a contagem de referência nesse objeto.

Sintaxe

PDEVICE_OBJECT IoGetAttachedDeviceReference(
  [in] PDEVICE_OBJECT DeviceObject
);

Parâmetros

[in] DeviceObject

Ponteiro para o objeto de dispositivo para o qual o objeto de dispositivo anexado mais alto é recuperado.

Retornar valor

IoGetAttachedDeviceReference retorna um ponteiro para o objeto de dispositivo de nível mais alto em uma pilha de objetos de dispositivo anexados depois de incrementar a contagem de referência no objeto .

Comentários

Se o objeto de dispositivo em DeviceObject não tiver nenhum objeto de dispositivo anexado a ele, DeviceObject e o ponteiro retornado serão iguais.

Os gravadores de driver de dispositivo devem garantir que, quando tiverem concluído todas as operações que exigem que eles façam essa chamada, chamem ObDereferenceObject com o ponteiro do objeto do dispositivo retornado por essa rotina. Não fazer isso impedirá que o sistema libere ou exclua o objeto de dispositivo devido a uma contagem de referência pendente.

Requisitos

Requisito Valor
Cliente mínimo com suporte Disponível a partir do Windows 2000.
Plataforma de Destino Universal
Cabeçalho wdm.h (include Wdm.h, Ntddk.h, Ntifs.h)
Biblioteca NtosKrnl.lib
DLL NtosKrnl.exe
IRQL <= DISPATCH_LEVEL
Regras de conformidade da DDI DanglingDeviceObjectReference(wdm), HwStorPortProhibitedDIs(storport)

Confira também

ObDereferenceObject