Compartilhar via


Função de retorno de chamada PFNKSFILTERIRP (ks.h)

A rotina AVStrMiniFilterCreate de um minidriver AVStream é chamada quando um filtro recebe um IRP.

IRP_MJ_CREATE

IRP_MJ_CLOSE

Sintaxe

PFNKSFILTERIRP Pfnksfilterirp;

NTSTATUS Pfnksfilterirp(
  [in] PKSFILTER Filter,
  [in] PIRP Irp
)
{...}

Parâmetros

[in] Filter

Ponteiro para o KSFILTER.

[in] Irp

Ponteiro para o IRP para Filtro.

Retornar valor

Se a rotina for bem-sucedida, retorne STATUS_SUCCESS ou o código de erro.

Comentários

IRP Descrição
IRP_MJ_CREATE Normalmente, essa rotina é usada por minidrivers que desejam inicializar o contexto e os recursos associados ao filtro. O minidriver especifica o endereço dessa rotina no membro Create de sua estrutura KSFILTER_DISPATCH . No ponto em que a rotina é chamada, o objeto de arquivo tem um contexto associado e o cabeçalho do objeto KS foi alocado. Essa rotina é chamada em IRQL = PASSIVE_LEVEL com o mutex do dispositivo mantido. Se a rotina for bem-sucedida, a operação de criação terá êxito. Retorne STATUS_SUCCESS ou o código de erro retornado da tentativa de criar o filtro. STATUS_PENDING também é um código de retorno legal. Se um minidriver retornar STATUS_PENDING, o AVStream não concluirá o IRP_MJ_CREATE imediatamente. Antes de retornar STATUS_PENDING, o minidriver deve chamar IoMarkIrpPending. Quando o processamento da criação for concluído, o minidriver deverá definir o código status do IRP e, em seguida, chamar KsCompletePendingRequest. Essa rotina é opcional.
IRP_MJ_CLOSE O minidriver especifica o endereço dessa rotina no membro Close de sua estrutura de KSFILTER_DISPATCH . No ponto em que a rotina é chamada, todos os eventos registrados no filtro foram liberados, mas o objeto está intacto de outra forma. Essa rotina é chamada em IRQL = PASSIVE_LEVEL com o mutex do dispositivo mantido. Para obter mais informações sobre mutexes, consulte Mutexes no AVStream. Essa rotina é opcional. Retornar STATUS_SUCCESS ou STATUS_PENDING. Se um minidriver retornar STATUS_PENDING, o AVStream não concluirá o IRP_MJ_CLOSE imediatamente. No entanto, antes de retornar STATUS_PENDING, o minidriver deve chamar IoMarkIrpPending. Depois que o processamento do fechamento for concluído, o minidriver deverá definir o código status do IRP e, em seguida, chamar KsCompletePendingRequest.

Requisitos

Requisito Valor
Plataforma de Destino Área de Trabalho
Cabeçalho ks.h (inclua Ks.h)
IRQL PASSIVE_LEVEL (consulte a seção Comentários)

Confira também

IoMarkIrpPending

KSFILTER_DISPATCHKsCompletePendingRequest