2 * COPYRIGHT: See COPYING in the top level directory
3 * PROJECT: ReactOS kernel
4 * FILE: ntoskrnl/io/flush.c
5 * PURPOSE: Flushing file buffer
6 * PROGRAMMER: David Welch (welch@cwcom.net)
11 /* INCLUDES *****************************************************************/
13 #include <ddk/ntddk.h>
14 #include <internal/ob.h>
17 #include <internal/debug.h>
19 /* FUNCTIONS *****************************************************************/
24 NtFlushWriteBuffer(VOID
)
27 return STATUS_SUCCESS
;
34 OUT PIO_STATUS_BLOCK IoStatusBlock
37 * FUNCTION: Flushes cached file data to disk
39 * FileHandle = Points to the file
40 * IoStatusBlock = Caller must supply storage to receive the result of
41 * the flush buffers operation. The information field is
42 * set to number of bytes flushed to disk.
44 * REMARKS: This function maps to the win32 FlushFileBuffers
47 PFILE_OBJECT FileObject
= NULL
;
49 PIO_STACK_LOCATION StackPtr
;
53 Status
= ObReferenceObjectByHandle(FileHandle
,
59 if (Status
!= STATUS_SUCCESS
)
63 KeResetEvent( &FileObject
->Event
);
64 Irp
= IoBuildSynchronousFsdRequest(IRP_MJ_FLUSH_BUFFERS
,
65 FileObject
->DeviceObject
,
72 //trigger FileObject/Event dereferencing
73 Irp
->Tail
.Overlay
.OriginalFileObject
= FileObject
;
75 StackPtr
= IoGetNextIrpStackLocation(Irp
);
76 StackPtr
->FileObject
= FileObject
;
78 Status
= IoCallDriver(FileObject
->DeviceObject
,Irp
);
79 if (Status
==STATUS_PENDING
)
81 KeWaitForSingleObject(&FileObject
->Event
,Executive
,KernelMode
,FALSE
,NULL
);
86 *IoStatusBlock
= IoSB
;