Compartilhar via


FLT_PARAMETERS para união IRP_MJ_MDL_READ

O membro da união FLT_PARAMETERS a seguir será utilizado quando FLT_IO_PARAMETER_BLOCK.MajorFunction for IRP_MJ_MDL_READ.

Sintaxe

typedef union _FLT_PARAMETERS {
  ...    ;
  struct {
    LARGE_INTEGER           FileOffset;
    ULONG POINTER_ALIGNMENT Length;
    ULONG POINTER_ALIGNMENT Key;
    PMDL                    *MdlChain;
  } MdlRead;
  ...    ;
} FLT_PARAMETERS, *PFLT_PARAMETERS;

Membros

  • MdlRead: estrutura que contém os membros a seguir.

  • FileOffset: byte inicial no arquivo armazenado em cache.

  • Length: o comprimento, em bytes, dos dados que serão lidos do arquivo armazenado em cache.

  • Key: valor de chave associado a um bloqueio de intervalo de bytes no arquivo de destino. Se o intervalo a ser lido se sobrepor ou for um subintervalo de um intervalo exclusivamente bloqueado dentro do arquivo, esse parâmetro precisará ser a chave para esse bloqueio exclusivo. O bloqueio exclusivo deve ser mantido pelo processo pai do thread de chamada, senão esse parâmetro será ignorado.

  • MdlChain: ponteiro para uma variável que recebe um ponteiro para uma cadeia de uma ou mais listas de descritores de memória (MDL) que descrevem as páginas que contêm os dados que serão lidos.

Comentários

IRP_MJ_MDL_READ é uma operação de E/S rápida. Ele faz a mesma coisa que IRP_MJ_READ + IRP_MN_MDL, exceto pela seguinte diferença:

  • A operação baseada em IRP configura o armazenamento em cache no arquivo, caso ainda não tenha sido armazenado em cache antes do trabalho da MDL.
  • A operação de E/S rápida falhará se o arquivo ainda não tiver sido armazenado em cache.

A estrutura FLT_PARAMETERS para operações IIRP_MN_MDL contém os parâmetros para uma operação de E/S rápida MdlRead. A operação é representada por uma estrutura (FLT_CALLBACK_DATA), com os parâmetros da operação na estrutura FLT_IO_PARAMETER_BLOCK para a qual Iopb aponta.

Se uma solicitação de E/S rápida IRP_MJ_MDL_READ falhar, o emissor da E/S definirá como reemitir a solicitação. Por exemplo, a solicitação pode ser reemitida como uma operação baseada em IRP usando IRP_MJ_READ + IRP_MN_MDL.

Requisitos

Tipo de requisito Requisito
Cabeçalho Fltkernel.h (inclui Fltkernel.h)

Confira também

FLT_CALLBACK_DATA

FLT_IO_PARAMETER_BLOCK

FLT_IS_FASTIO_OPERATION

FLT_IS_FS_FILTER_OPERATION

FLT_IS_IRP_OPERATION

FLT_PARAMETERS