2005-09-04 21:44:02 +00:00
|
|
|
/*
|
2007-04-18 01:25:28 +00:00
|
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
|
|
* PROJECT: ReactOS kernel
|
2012-09-29 08:19:24 +00:00
|
|
|
* FILE: drivers/filesystems/npfs/volume.c
|
2007-04-18 01:25:28 +00:00
|
|
|
* PURPOSE: Named pipe filesystem
|
|
|
|
* PROGRAMMER: Eric Kohl
|
|
|
|
*/
|
2001-06-12 12:35:42 +00:00
|
|
|
|
|
|
|
/* INCLUDES *****************************************************************/
|
|
|
|
|
2007-04-18 01:51:27 +00:00
|
|
|
#include "npfs.h"
|
|
|
|
|
2001-06-12 12:35:42 +00:00
|
|
|
#define NDEBUG
|
|
|
|
#include <debug.h>
|
|
|
|
|
|
|
|
/* FUNCTIONS ****************************************************************/
|
|
|
|
|
2013-08-31 07:07:43 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NpQueryFsDeviceInformation(IN PFILE_FS_DEVICE_INFORMATION FsDeviceInfo,
|
|
|
|
OUT PULONG BufferLength)
|
2001-06-12 12:35:42 +00:00
|
|
|
{
|
2013-08-31 07:07:43 +00:00
|
|
|
PAGED_CODE();
|
2009-02-08 09:04:42 +00:00
|
|
|
DPRINT("NpfsQueryFsDeviceInformation()\n");
|
|
|
|
DPRINT("FsDeviceInfo = %p\n", FsDeviceInfo);
|
2005-02-27 12:43:37 +00:00
|
|
|
|
2009-02-08 09:04:42 +00:00
|
|
|
if (*BufferLength < sizeof(FILE_FS_DEVICE_INFORMATION))
|
2010-06-01 08:43:50 +00:00
|
|
|
{
|
2009-02-08 09:04:42 +00:00
|
|
|
return STATUS_BUFFER_OVERFLOW;
|
2010-06-01 08:43:50 +00:00
|
|
|
}
|
2005-02-27 12:43:37 +00:00
|
|
|
|
2009-02-08 09:04:42 +00:00
|
|
|
FsDeviceInfo->DeviceType = FILE_DEVICE_NAMED_PIPE;
|
|
|
|
FsDeviceInfo->Characteristics = 0;
|
2005-02-27 12:43:37 +00:00
|
|
|
|
2013-08-31 07:07:43 +00:00
|
|
|
*BufferLength -= sizeof(FILE_FS_DEVICE_INFORMATION);
|
2005-02-27 12:43:37 +00:00
|
|
|
|
2009-02-08 09:04:42 +00:00
|
|
|
DPRINT("NpfsQueryFsDeviceInformation() finished.\n");
|
2005-02-27 12:43:37 +00:00
|
|
|
|
2009-02-08 09:04:42 +00:00
|
|
|
return STATUS_SUCCESS;
|
2001-06-12 12:35:42 +00:00
|
|
|
}
|
|
|
|
|
2013-08-31 07:07:43 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NpQueryFsFullSizeInfo(IN PFILE_FS_FULL_SIZE_INFORMATION FsSizeInfo,
|
|
|
|
OUT PULONG BufferSize)
|
|
|
|
{
|
|
|
|
RtlZeroMemory(FsSizeInfo, sizeof(FILE_FS_FULL_SIZE_INFORMATION));
|
|
|
|
*BufferSize -= sizeof(FILE_FS_FULL_SIZE_INFORMATION);
|
|
|
|
return STATUS_SUCCESS;
|
|
|
|
}
|
2001-06-12 12:35:42 +00:00
|
|
|
|
2013-08-31 07:07:43 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NpQueryFsSizeInfo(IN PFILE_FS_SIZE_INFORMATION FsSizeInfo,
|
|
|
|
OUT PULONG BufferSize)
|
2001-06-12 12:35:42 +00:00
|
|
|
{
|
2013-08-31 07:07:43 +00:00
|
|
|
FsSizeInfo->TotalAllocationUnits.LowPart = 0;
|
|
|
|
FsSizeInfo->TotalAllocationUnits.HighPart = 0;
|
|
|
|
FsSizeInfo->AvailableAllocationUnits.LowPart = 0;
|
|
|
|
FsSizeInfo->AvailableAllocationUnits.HighPart = 0;
|
|
|
|
FsSizeInfo->SectorsPerAllocationUnit = 1;
|
|
|
|
FsSizeInfo->BytesPerSector = 1;
|
|
|
|
*BufferSize -= sizeof(FILE_FS_SIZE_INFORMATION);
|
|
|
|
return STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NpQueryFsAttributeInformation(IN PFILE_FS_ATTRIBUTE_INFORMATION FsAttributeInfo,
|
|
|
|
OUT PULONG BufferLength)
|
|
|
|
{
|
|
|
|
PAGED_CODE();
|
2009-02-08 09:04:42 +00:00
|
|
|
DPRINT("NpfsQueryFsAttributeInformation() called.\n");
|
|
|
|
DPRINT("FsAttributeInfo = %p\n", FsAttributeInfo);
|
2005-02-27 12:43:37 +00:00
|
|
|
|
2009-02-08 09:04:42 +00:00
|
|
|
if (*BufferLength < sizeof(FILE_FS_ATTRIBUTE_INFORMATION) + 8)
|
2010-06-01 08:43:50 +00:00
|
|
|
{
|
2013-08-31 07:07:43 +00:00
|
|
|
*BufferLength = 0;
|
2009-02-08 09:04:42 +00:00
|
|
|
return STATUS_BUFFER_OVERFLOW;
|
2010-06-01 08:43:50 +00:00
|
|
|
}
|
2005-02-27 12:43:37 +00:00
|
|
|
|
2009-02-08 09:04:42 +00:00
|
|
|
FsAttributeInfo->FileSystemAttributes = FILE_CASE_PRESERVED_NAMES;
|
2013-08-31 07:07:43 +00:00
|
|
|
FsAttributeInfo->MaximumComponentNameLength = -1;
|
2009-02-08 09:04:42 +00:00
|
|
|
FsAttributeInfo->FileSystemNameLength = 8;
|
2013-08-31 07:07:43 +00:00
|
|
|
wcscpy(FsAttributeInfo->FileSystemName, L"NPFS");
|
2005-02-27 12:43:37 +00:00
|
|
|
|
2009-02-08 09:04:42 +00:00
|
|
|
DPRINT("NpfsQueryFsAttributeInformation() finished.\n");
|
2013-08-31 07:07:43 +00:00
|
|
|
*BufferLength -= (sizeof(FILE_FS_ATTRIBUTE_INFORMATION) + 8);
|
2005-02-27 12:43:37 +00:00
|
|
|
|
2009-02-08 09:04:42 +00:00
|
|
|
return STATUS_SUCCESS;
|
2001-06-12 12:35:42 +00:00
|
|
|
}
|
|
|
|
|
2013-08-31 07:07:43 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NpCommonQueryVolumeInformation(IN PIRP Irp)
|
2001-06-12 12:35:42 +00:00
|
|
|
{
|
2009-02-08 09:04:42 +00:00
|
|
|
PIO_STACK_LOCATION Stack;
|
|
|
|
FS_INFORMATION_CLASS FsInformationClass;
|
|
|
|
PVOID SystemBuffer;
|
|
|
|
ULONG BufferLength;
|
2013-08-31 07:07:43 +00:00
|
|
|
NTSTATUS Status;
|
|
|
|
PAGED_CODE();
|
2009-02-08 09:04:42 +00:00
|
|
|
|
|
|
|
Stack = IoGetCurrentIrpStackLocation(Irp);
|
|
|
|
FsInformationClass = Stack->Parameters.QueryVolume.FsInformationClass;
|
|
|
|
BufferLength = Stack->Parameters.QueryVolume.Length;
|
|
|
|
SystemBuffer = Irp->AssociatedIrp.SystemBuffer;
|
|
|
|
|
|
|
|
DPRINT("FsInformationClass %d\n", FsInformationClass);
|
|
|
|
DPRINT("SystemBuffer %p\n", SystemBuffer);
|
|
|
|
|
|
|
|
switch (FsInformationClass)
|
|
|
|
{
|
2013-08-31 07:07:43 +00:00
|
|
|
case FileFsFullSizeInformation:
|
|
|
|
Status = NpQueryFsFullSizeInfo(SystemBuffer, &BufferLength);
|
|
|
|
break;
|
|
|
|
case FileFsSizeInformation:
|
|
|
|
Status = NpQueryFsSizeInfo(SystemBuffer, &BufferLength);
|
|
|
|
break;
|
|
|
|
|
2009-02-08 09:04:42 +00:00
|
|
|
case FileFsDeviceInformation:
|
2013-08-31 07:07:43 +00:00
|
|
|
Status = NpQueryFsDeviceInformation(SystemBuffer, &BufferLength);
|
2009-02-08 09:04:42 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case FileFsAttributeInformation:
|
2013-08-31 07:07:43 +00:00
|
|
|
Status = NpQueryFsAttributeInformation(SystemBuffer, &BufferLength);
|
2009-02-08 09:04:42 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
2013-08-31 07:07:43 +00:00
|
|
|
DPRINT1("Query not implemented: %d\n", FsInformationClass);
|
2009-02-08 09:04:42 +00:00
|
|
|
Status = STATUS_NOT_SUPPORTED;
|
|
|
|
}
|
|
|
|
|
2013-08-31 07:07:43 +00:00
|
|
|
Irp->IoStatus.Information = Stack->Parameters.QueryVolume.Length - BufferLength;
|
|
|
|
return Status;
|
|
|
|
}
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NpfsQueryVolumeInformation(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp)
|
|
|
|
{
|
|
|
|
NTSTATUS Status;
|
|
|
|
PAGED_CODE();
|
|
|
|
DPRINT("NpfsQueryVolumeInformation(DeviceObject %p, Irp %p)\n", DeviceObject, Irp);
|
|
|
|
|
|
|
|
FsRtlEnterFileSystem();
|
|
|
|
Status = NpCommonQueryVolumeInformation(Irp);
|
|
|
|
FsRtlExitFileSystem();
|
2010-06-01 08:43:50 +00:00
|
|
|
|
2013-08-31 07:07:43 +00:00
|
|
|
if (Status != STATUS_PENDING)
|
|
|
|
{
|
|
|
|
Irp->IoStatus.Status = Status;
|
|
|
|
|
|
|
|
IoCompleteRequest(Irp, IO_DISK_INCREMENT);
|
|
|
|
}
|
2009-02-08 09:04:42 +00:00
|
|
|
|
|
|
|
return Status;
|
2001-06-12 12:35:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* EOF */
|