Compartilhar via


Função FsRtlCopyRead (ntifs.h)

A rotina FsRtlCopyRead copia dados de um arquivo armazenado em cache para um buffer de usuário.

Sintaxe

BOOLEAN FsRtlCopyRead(
  [in]  PFILE_OBJECT     FileObject,
  [in]  PLARGE_INTEGER   FileOffset,
  [in]  ULONG            Length,
  [in]  BOOLEAN          Wait,
  [in]  ULONG            LockKey,
  [out] PVOID            Buffer,
  [out] PIO_STATUS_BLOCK IoStatus,
  [in]  PDEVICE_OBJECT   DeviceObject
);

Parâmetros

[in] FileObject

Ponteiro para um objeto de arquivo para o arquivo armazenado em cache do qual os dados devem ser lidos.

[in] FileOffset

Iniciando o deslocamento de bytes dentro do arquivo armazenado em cache.

[in] Length

Comprimento em bytes dos dados a serem lidos.

[in] Wait

Defina como TRUE se o chamador puder ser colocado em um estado de espera até que todos os dados sejam copiados, FALSE caso contrário.

[in] LockKey

Um valor associado ao intervalo de bytes a ser bloqueado. Se o intervalo a ser bloqueado se sobrepor a outro intervalo que já está bloqueado com um bloqueio nãoclusivo ou se o intervalo a ser lido for um subconjunto de outro intervalo que já está bloqueado de forma inexistente, o valor nesse parâmetro deve ser a chave para esse bloqueio nãoclusivo O bloqueio deve ser mantido pelo processo pai do thread de chamada. Caso contrário, esse parâmetro não terá efeito.

[out] Buffer

Ponteiro para um buffer no qual os dados devem ser copiados.

[out] IoStatus

Ponteiro para uma estrutura alocada por chamador que recebe o status de conclusão final e informações sobre a operação. Se os dados forem copiados com êxito, IoStatus.Status conterá STATUS_SUCCESS. Se nem todos os dados forem copiados com êxito, IoStatus.Information contém o número real de bytes que foram copiados.

[in] DeviceObject

O objeto do dispositivo que contém os dados do arquivo.

Valor de retorno

FsRtlCopyRead retornará TRUE se a solicitação de cópia tiver sido concluída, CASO contrário, FALSE. Observe que um valor retornado de TRUE não significa necessariamente que a operação de cópia foi bem-sucedida.

Se FsRtlCopyRead retornar FALSE ou se o conteúdo de IoStatus indicar que a operação de cópia falhou, o chamador deverá alocar um IRP de leitura em vez de chamar FsRtlCopyRead.

Observações

Em vez de implementar uma rotina de leitura rápida de E/S específica do sistema de arquivos, os desenvolvedores de sistemas de arquivos que dão suporte ao cache de arquivos devem considerar o uso FsRtlCopyRead como ponto de entrada do sistema de arquivos para processar solicitações rápidas de leitura de E/S. Isso requer que a rotina de DriverEntry do sistema de arquivos defina o ponto de entrada FastIoRead como FsRtlCopyRead na estrutura FAST_IO_DISPATCH do objeto do driver do sistema de arquivos. Além disso, o sistema de arquivos deve fazer o seguinte:

  1. Para cada arquivo no qual a E/S rápida pode ser executada, o sistema de arquivos deve alocar e inicializar uma estrutura de FSRTL_COMMON_FCB_HEADER.

    Na maioria dos sistemas de arquivos, isso é feito incluindo a estrutura FSRTL_COMMON_FCB_HEADER em um FCB (bloco de controle de arquivo) ou estrutura comparável que é usada para manter o estado de um arquivo aberto.

    O armazenamento para a estrutura de FSRTL_COMMON_FCB_HEADER normalmente é alocado do pool de páginas.

  2. Para cada arquivo no qual a E/S rápida pode ser executada, o sistema de arquivos deve vincular quaisquer objetos de arquivo para o arquivo à estrutura FSRTL_COMMON_FCB_HEADER. Isso é feito definindo o membro FsContext de cada objeto de arquivo para apontar para essa estrutura (ou o FCB ou outra estrutura que contém a estrutura FSRTL_COMMON_FCB_HEADER).

  3. Ao armazenar em cache um arquivo, o sistema de arquivos deve definir o isFastIoPossible membro da estrutura FSRTL_COMMON_FCB_HEADER do arquivo como um valor apropriado. Esse valor deve ser atualizado conforme necessário, desde que o arquivo permaneça armazenado em cache.

    Em particular, os sistemas de arquivos devem definir o membro IsFastIoPossible da estrutura FSRTL_COMMON_FCB_HEADER para FastIoIsQuestionable assim que houver qualquer bloqueio exclusivo de intervalo de bytes no arquivo armazenado em cache.

Se de Espera for TRUE, FsRtlCopyRead será garantido para concluir a solicitação de cópia e retornar TRUE. Se as páginas necessárias do arquivo armazenado em cache já estiverem residentes na memória, os dados serão copiados imediatamente e nenhum bloqueio ocorrerá. Se as páginas necessárias não forem residentes, o chamador será colocado em um estado de espera até que todas as páginas necessárias sejam residentes e os dados possam ser copiados.

Se de Espera for FALSE, FsRtlCopyRead se recusará a bloquear e retornará FALSE se não puder adquirir o recurso principal do arquivo ou se as páginas necessárias do arquivo armazenado em cache ainda não estiverem residentes na memória.

A rotina de FastIoCheckIfPossible do sistema de arquivos é responsável por garantir que o intervalo de bytes definido por FileOffset e Length não inclua nenhum intervalo de bytes bloqueado exclusivamente para o qual o chamador não passa o valor de do LockKey apropriado. Se o sistema de arquivos usar as rotinas de suporte FsRtlXxxLockYyyy para gerenciar bloqueios de intervalo de bytes, isso pode ser feito chamando FsRtlFastCheckLockForRead da rotina FastIoCheckIfPoss ible antes de chamar FsRtlCopyRead.

Para armazenar em cache um arquivo, use a rotina de ccInitializeCacheMap .

Requisitos

Requisito Valor
da Plataforma de Destino Universal
cabeçalho ntifs.h (inclua Ntifs.h)
biblioteca NtosKrnl.lib
de DLL NtosKrnl.exe
IRQL PASSIVE_LEVEL
regras de conformidade de DDI PowerIrpDDis(wdm)

Consulte também

CcInitializeCacheMap

FsRtlCopyWrite

FsRtlFastCheckLockForRead