2005-08-24 18:29:45 +00:00
|
|
|
/*
|
2000-12-29 13:45:01 +00:00
|
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
|
|
* PROJECT: ReactOS kernel
|
2003-10-11 17:51:56 +00:00
|
|
|
* FILE: drivers/fs/vfat/shutdown.c
|
2000-12-29 13:45:01 +00:00
|
|
|
* PURPOSE: VFAT Filesystem
|
2010-01-09 22:43:16 +00:00
|
|
|
* PROGRAMMER: Eric Kohl
|
2000-12-29 13:45:01 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES *****************************************************************/
|
|
|
|
|
2001-05-01 23:08:21 +00:00
|
|
|
#define NDEBUG
|
2000-12-29 13:45:01 +00:00
|
|
|
#include "vfat.h"
|
|
|
|
|
|
|
|
/* FUNCTIONS ****************************************************************/
|
|
|
|
|
2005-10-06 21:39:18 +00:00
|
|
|
static NTSTATUS
|
2005-02-16 15:27:30 +00:00
|
|
|
VfatDiskShutDown(PVCB Vcb)
|
|
|
|
{
|
|
|
|
PIRP Irp;
|
|
|
|
KEVENT Event;
|
|
|
|
NTSTATUS Status;
|
|
|
|
IO_STATUS_BLOCK IoStatus;
|
|
|
|
|
|
|
|
KeInitializeEvent(&Event, NotificationEvent, FALSE);
|
|
|
|
Irp = IoBuildSynchronousFsdRequest(IRP_MJ_SHUTDOWN, Vcb->StorageDevice,
|
|
|
|
NULL, 0, NULL, &Event, &IoStatus);
|
|
|
|
if (Irp)
|
|
|
|
{
|
|
|
|
Status = IoCallDriver(Vcb->StorageDevice, Irp);
|
|
|
|
if (Status == STATUS_PENDING)
|
|
|
|
{
|
|
|
|
KeWaitForSingleObject(&Event, Executive, KernelMode, FALSE, NULL);
|
|
|
|
Status = IoStatus.Status;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Status = IoStatus.Status;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Status;
|
|
|
|
}
|
|
|
|
|
2005-10-03 07:15:12 +00:00
|
|
|
NTSTATUS NTAPI
|
2000-12-29 13:45:01 +00:00
|
|
|
VfatShutdown(PDEVICE_OBJECT DeviceObject, PIRP Irp)
|
|
|
|
{
|
|
|
|
NTSTATUS Status;
|
2003-02-09 18:02:56 +00:00
|
|
|
PLIST_ENTRY ListEntry;
|
|
|
|
PDEVICE_EXTENSION DeviceExt;
|
2005-04-16 16:04:38 +00:00
|
|
|
ULONG eocMark;
|
2000-12-29 13:45:01 +00:00
|
|
|
|
2007-11-21 16:50:07 +00:00
|
|
|
DPRINT("VfatShutdown(DeviceObject %p, Irp %p)\n",DeviceObject, Irp);
|
2000-12-29 13:45:01 +00:00
|
|
|
|
2008-01-12 15:20:22 +00:00
|
|
|
FsRtlEnterFileSystem();
|
|
|
|
|
2001-01-14 15:28:50 +00:00
|
|
|
/* FIXME: block new mount requests */
|
|
|
|
|
2003-02-09 18:02:56 +00:00
|
|
|
if (DeviceObject == VfatGlobalData->DeviceObject)
|
|
|
|
{
|
|
|
|
Irp->IoStatus.Status = STATUS_SUCCESS;
|
|
|
|
ExAcquireResourceExclusiveLite(&VfatGlobalData->VolumeListLock, TRUE);
|
|
|
|
ListEntry = VfatGlobalData->VolumeListHead.Flink;
|
|
|
|
while (ListEntry != &VfatGlobalData->VolumeListHead)
|
|
|
|
{
|
|
|
|
DeviceExt = CONTAINING_RECORD(ListEntry, VCB, VolumeListEntry);
|
|
|
|
ListEntry = ListEntry->Flink;
|
|
|
|
|
|
|
|
ExAcquireResourceExclusiveLite(&DeviceExt->DirResource, TRUE);
|
2005-04-16 16:04:38 +00:00
|
|
|
if (DeviceExt->VolumeFcb->Flags & VCB_CLEAR_DIRTY)
|
|
|
|
{
|
|
|
|
/* set clean shutdown bit */
|
|
|
|
Status = GetNextCluster(DeviceExt, 1, &eocMark);
|
|
|
|
if (NT_SUCCESS(Status))
|
|
|
|
{
|
|
|
|
eocMark |= DeviceExt->CleanShutBitMask;
|
|
|
|
if (NT_SUCCESS(WriteCluster(DeviceExt, 1, eocMark)))
|
|
|
|
DeviceExt->VolumeFcb->Flags &= ~VCB_IS_DIRTY;
|
|
|
|
}
|
|
|
|
}
|
2003-02-09 18:02:56 +00:00
|
|
|
Status = VfatFlushVolume(DeviceExt, DeviceExt->VolumeFcb);
|
2005-02-16 15:27:30 +00:00
|
|
|
if (NT_SUCCESS(Status))
|
|
|
|
{
|
|
|
|
Status = VfatDiskShutDown(DeviceExt);
|
|
|
|
if (!NT_SUCCESS(Status))
|
|
|
|
DPRINT1("VfatDiskShutDown failed, status = %x\n", Status);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2003-02-09 18:02:56 +00:00
|
|
|
DPRINT1("VfatFlushVolume failed, status = %x\n", Status);
|
|
|
|
}
|
2005-02-16 15:27:30 +00:00
|
|
|
ExReleaseResourceLite(&DeviceExt->DirResource);
|
|
|
|
|
2003-02-09 18:02:56 +00:00
|
|
|
/* FIXME: Unmount the logical volume */
|
2005-02-16 15:27:30 +00:00
|
|
|
|
|
|
|
if (!NT_SUCCESS(Status))
|
|
|
|
Irp->IoStatus.Status = Status;
|
2003-02-09 18:02:56 +00:00
|
|
|
}
|
2005-02-16 15:27:30 +00:00
|
|
|
ExReleaseResourceLite(&VfatGlobalData->VolumeListLock);
|
2005-05-08 02:16:32 +00:00
|
|
|
|
2003-02-09 18:02:56 +00:00
|
|
|
/* FIXME: Free all global acquired resources */
|
|
|
|
|
|
|
|
Status = Irp->IoStatus.Status;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2005-02-16 15:27:30 +00:00
|
|
|
Irp->IoStatus.Status = STATUS_INVALID_DEVICE_REQUEST;
|
2003-02-09 18:02:56 +00:00
|
|
|
Status = STATUS_INVALID_DEVICE_REQUEST;
|
|
|
|
}
|
2000-12-29 13:45:01 +00:00
|
|
|
|
|
|
|
Irp->IoStatus.Information = 0;
|
|
|
|
IoCompleteRequest(Irp, IO_NO_INCREMENT);
|
2005-02-16 15:27:30 +00:00
|
|
|
|
2008-01-12 15:20:22 +00:00
|
|
|
FsRtlExitFileSystem();
|
|
|
|
|
2000-12-29 13:45:01 +00:00
|
|
|
return(Status);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* EOF */
|