3 * COPYRIGHT: See COPYING in the top level directory
4 * PROJECT: ReactOS kernel
5 * FILE: ntoskrnl/io/page.c
12 /* INCLUDES *****************************************************************/
14 #include <ddk/ntddk.h>
15 #include <internal/io.h>
18 #include <internal/debug.h>
20 /* FUNCTIONS *****************************************************************/
25 IoPageWrite(PFILE_OBJECT FileObject,
27 PLARGE_INTEGER Offset,
29 PIO_STATUS_BLOCK StatusBlock)
32 PIO_STACK_LOCATION StackPtr;
35 DPRINT("IoPageWrite(FileObject %x, Mdl %x)\n",
38 Irp = IoBuildSynchronousFsdRequestWithMdl(IRP_MJ_WRITE,
39 FileObject->DeviceObject,
47 return (STATUS_INSUFFICIENT_RESOURCES);
49 Irp->Flags = IRP_NOCACHE|IRP_PAGING_IO;
50 StackPtr = IoGetNextIrpStackLocation(Irp);
51 StackPtr->FileObject = FileObject;
52 DPRINT("Before IoCallDriver\n");
53 Status = IofCallDriver(FileObject->DeviceObject,Irp);
54 DPRINT("Status %d STATUS_PENDING %d\n",Status,STATUS_PENDING);
58 #endif /* LIBCAPTIVE */
61 IoPageRead(PFILE_OBJECT FileObject,
63 PLARGE_INTEGER Offset,
65 PIO_STATUS_BLOCK StatusBlock)
68 PIO_STACK_LOCATION StackPtr;
71 DPRINT("IoPageRead(FileObject %x, Mdl %x)\n",
74 Irp = IoBuildSynchronousFsdRequestWithMdl(IRP_MJ_READ,
75 FileObject->DeviceObject,
83 return (STATUS_INSUFFICIENT_RESOURCES);
85 Irp->Flags = IRP_NOCACHE
88 #else /* !LIBCAPTIVE */
89 /* IRP_SYNCHRONOUS_PAGING_IO: We need to prevent STATUS_PENDING
90 * IRP_PAGING_IO: We need to pass check in W32 filesystem as we are FO_CLEANUP_COMPLETE (why?)
92 |IRP_PAGING_IO|IRP_SYNCHRONOUS_PAGING_IO;
93 #endif /* !LIBCAPTIVE */
94 StackPtr = IoGetNextIrpStackLocation(Irp);
95 StackPtr->FileObject = FileObject;
96 DPRINT("Before IoCallDriver\n");
97 Status = IofCallDriver(FileObject->DeviceObject, Irp);
98 /* FIXME: IoBuildSynchronousFsdRequestWithMdl() will fill 'StatusBlock' to 'Irp->UserIoSb'
99 * but W32 filesystem takes care just of 'Irp->IoStatus'. Hack it back here.
101 *StatusBlock=Irp->IoStatus;
102 DPRINT("Status %d STATUS_PENDING %d\n",Status,STATUS_PENDING);
110 IoSynchronousPageWrite (PFILE_OBJECT FileObject,
112 PLARGE_INTEGER Offset,
114 PIO_STATUS_BLOCK StatusBlock)
117 PIO_STACK_LOCATION StackPtr;
120 DPRINT("IoSynchronousPageWrite(FileObject %x, Mdl %x)\n",
123 Irp = IoBuildSynchronousFsdRequestWithMdl(IRP_MJ_WRITE,
124 FileObject->DeviceObject,
132 return (STATUS_INSUFFICIENT_RESOURCES);
134 Irp->Flags = IRP_NOCACHE|IRP_PAGING_IO|IRP_SYNCHRONOUS_PAGING_IO;
135 StackPtr = IoGetNextIrpStackLocation(Irp);
136 StackPtr->FileObject = FileObject;
137 DPRINT("Before IoCallDriver\n");
138 Status = IofCallDriver(FileObject->DeviceObject,Irp);
139 DPRINT("Status %d STATUS_PENDING %d\n",Status,STATUS_PENDING);
143 #endif /* LIBCAPTIVE */