Upravit

Sdílet prostřednictvím


CcZeroData function (ntifs.h)

The CcZeroData routine zeros the specified range of bytes in a cached or noncached file.

Note

This routine should only be called to zero portions of a file beyond the file's valid data length. CcZeroData will not modify any previously written data of the file. To zero previously written data that is portion of the file up to the file’s valid data length, call CcCopyWrite, or one of the other cached write interfaces.

Syntax

BOOLEAN CcZeroData(
  [in] PFILE_OBJECT   FileObject,
  [in] PLARGE_INTEGER StartOffset,
  [in] PLARGE_INTEGER EndOffset,
  [in] BOOLEAN        Wait
);

Parameters

[in] FileObject

A pointer to a FILE_OBJECT for the file in which a range of bytes is to be zeroed.

[in] StartOffset

A pointer to a variable that specifies the byte offset within the file to the first byte that is to be zeroed.

[in] EndOffset

A pointer to a variable that specifies the byte offset within the file to the last byte that is to be zeroed.

[in] Wait

Set to TRUE if the caller should be put into a wait state until the entire byte range has been zeroed. Otherwise, this parameter is set to FALSE.

Return value

CcZeroData returns TRUE if the data is zeroed successfully; otherwise, returns FALSE.

Remarks

The file to be zeroed can be cached or noncached. However, if the file is noncached, the values of StartOffset and EndOffset must both be multiples of the volume's sector size.

If a pool allocation failure occurs and Wait was specified as TRUE, CcZeroData raises a STATUS_INSUFFICIENT_RESOURCES exception. If a pool allocation failure occurs and Wait was specified as FALSE, CcZeroData returns FALSE, but does not raise an exception.

If the FileObject supplied does not have caching enabled, but caching exists on the stream (that is, another file object for the same file has caching enabled), then zeroing will be treated as though write-through caching is enabled.

If Wait is set to TRUE, CcZeroData is guaranteed to complete the zero data request and return TRUE. If the required pages of the cached file are already resident in memory, the data will be zeroed immediately and no blocking will occur. If any needed pages are not resident, the caller will be put in a wait state until all required pages have been made resident and the data can be zeroed.

If Wait is FALSE and if the required pages of the cached file are not already resident in memory, CcZeroData will refuse to block and will return FALSE.

If a pool allocation failure occurs, CcZeroData raises a STATUS_INSUFFICIENT_RESOURCES exception. If CcZeroData encounters any other errors, including IO errors, the errors will be raised to the caller.

For Windows Vista and later Windows operating systems, the behavior of CcZeroData is as follows:

  • If the stream is cached and write_through, StartOffset does not have to be sector aligned.
  • If EndOffset is not aligned, it will be rounded up to the next sector size.

Requirements

Requirement Value
Minimum supported client Windows 2000. See Remarks for changes for Vista and later operating systems.
Target Platform Universal
Header ntifs.h (include Fltkernel.h, Ntifs.h)
Library NtosKrnl.lib
DLL NtosKrnl.exe
IRQL <=APC_LEVEL

See also

CcInitializeCacheMap

CcIsFileCached

FILE_OBJECT