mirror of
https://github.com/reactos/reactos.git
synced 2025-01-04 21:38:43 +00:00
Fix ext2 recognizer compilation, but let it disabled atm
svn path=/trunk/; revision=32292
This commit is contained in:
parent
7b726051e8
commit
4797b6a8d5
5 changed files with 109 additions and 113 deletions
|
@ -1,136 +1,107 @@
|
||||||
/*
|
/*
|
||||||
* ReactOS kernel
|
|
||||||
* Copyright (C) 2002,2003 ReactOS Team
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
||||||
*/
|
|
||||||
/* $Id: fat.c 9284 2004-05-02 20:12:38Z hbirr $
|
|
||||||
*
|
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS File System Recognizer
|
||||||
* FILE: drivers/fs/fs_rec/ext2.c (based on vfat.c)
|
* FILE: drivers/filesystems/fs_rec/ext2.c
|
||||||
* PURPOSE: Filesystem recognizer driver
|
* PURPOSE: EXT2 Recognizer
|
||||||
* PROGRAMMER: Eric Kohl
|
* PROGRAMMER: Eric Kohl
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* INCLUDES *****************************************************************/
|
/* INCLUDES *****************************************************************/
|
||||||
|
|
||||||
#include <ddk/ntddk.h>
|
#include "fs_rec.h"
|
||||||
#include <rosrtl/string.h>
|
|
||||||
|
|
||||||
#define NDEBUG
|
#define NDEBUG
|
||||||
#include <debug.h>
|
#include <debug.h>
|
||||||
|
|
||||||
#include "fs_rec.h"
|
|
||||||
|
|
||||||
|
|
||||||
/* FUNCTIONS ****************************************************************/
|
/* FUNCTIONS ****************************************************************/
|
||||||
|
|
||||||
static NTSTATUS
|
BOOLEAN
|
||||||
FsRecIsExt2Volume(IN PDEVICE_OBJECT DeviceObject)
|
NTAPI
|
||||||
|
FsRecIsExt2Volume(IN PVOID PackedBootSector)
|
||||||
{
|
{
|
||||||
NTSTATUS Status;
|
/* For now, always return failure... */
|
||||||
PARTITION_INFORMATION PartitionInfo;
|
return FALSE;
|
||||||
DISK_GEOMETRY DiskGeometry;
|
|
||||||
ULONG Size;
|
|
||||||
BOOL RecognizedFS = FALSE;
|
|
||||||
Size = sizeof(DISK_GEOMETRY);
|
|
||||||
|
|
||||||
Status = FsRecDeviceIoControl(DeviceObject,
|
|
||||||
IOCTL_DISK_GET_DRIVE_GEOMETRY,
|
|
||||||
NULL,
|
|
||||||
0,
|
|
||||||
&DiskGeometry,
|
|
||||||
&Size);
|
|
||||||
if (!NT_SUCCESS(Status))
|
|
||||||
{
|
|
||||||
DPRINT("FsRecDeviceIoControl faild (%x)\n", Status);
|
|
||||||
return Status;
|
|
||||||
}
|
|
||||||
if (DiskGeometry.MediaType == FixedMedia || DiskGeometry.MediaType == RemovableMedia)
|
|
||||||
{
|
|
||||||
// We have found a hard disk
|
|
||||||
Size = sizeof(PARTITION_INFORMATION);
|
|
||||||
Status = FsRecDeviceIoControl(DeviceObject,
|
|
||||||
IOCTL_DISK_GET_PARTITION_INFO,
|
|
||||||
NULL,
|
|
||||||
0,
|
|
||||||
&PartitionInfo,
|
|
||||||
&Size);
|
|
||||||
if (!NT_SUCCESS(Status))
|
|
||||||
{
|
|
||||||
DPRINT("FsRecDeviceIoControl faild (%x)\n", Status);
|
|
||||||
return Status;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (PartitionInfo.PartitionType)
|
|
||||||
{
|
|
||||||
if (PartitionInfo.PartitionType == PARTITION_EXT2)
|
|
||||||
{
|
|
||||||
RecognizedFS = TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return RecognizedFS ? STATUS_SUCCESS : STATUS_UNRECOGNIZED_VOLUME;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
NTSTATUS
|
NTSTATUS
|
||||||
|
NTAPI
|
||||||
FsRecExt2FsControl(IN PDEVICE_OBJECT DeviceObject,
|
FsRecExt2FsControl(IN PDEVICE_OBJECT DeviceObject,
|
||||||
IN PIRP Irp)
|
IN PIRP Irp)
|
||||||
{
|
{
|
||||||
PIO_STACK_LOCATION Stack;
|
PIO_STACK_LOCATION Stack;
|
||||||
UNICODE_STRING RegistryPath;
|
|
||||||
NTSTATUS Status;
|
NTSTATUS Status;
|
||||||
|
PDEVICE_OBJECT MountDevice;
|
||||||
|
PVOID Bpb = NULL;
|
||||||
|
ULONG SectorSize;
|
||||||
|
LARGE_INTEGER Offset = {{0}};
|
||||||
|
BOOLEAN DeviceError = FALSE;
|
||||||
|
PAGED_CODE();
|
||||||
|
|
||||||
|
/* Get the I/O Stack and check the function type */
|
||||||
Stack = IoGetCurrentIrpStackLocation(Irp);
|
Stack = IoGetCurrentIrpStackLocation(Irp);
|
||||||
|
|
||||||
switch (Stack->MinorFunction)
|
switch (Stack->MinorFunction)
|
||||||
{
|
{
|
||||||
case IRP_MN_MOUNT_VOLUME:
|
case IRP_MN_MOUNT_VOLUME:
|
||||||
DPRINT("FAT: IRP_MN_MOUNT_VOLUME\n");
|
|
||||||
Status = FsRecIsExt2Volume(Stack->Parameters.MountVolume.DeviceObject);
|
/* Assume failure */
|
||||||
if (NT_SUCCESS(Status))
|
Status = STATUS_UNRECOGNIZED_VOLUME;
|
||||||
|
|
||||||
|
/* Get the device object and request the sector size */
|
||||||
|
MountDevice = Stack->Parameters.MountVolume.DeviceObject;
|
||||||
|
if (FsRecGetDeviceSectorSize(MountDevice, &SectorSize))
|
||||||
{
|
{
|
||||||
DPRINT("Identified FAT volume\n");
|
/* Try to read the BPB */
|
||||||
|
if (FsRecReadBlock(MountDevice,
|
||||||
|
&Offset,
|
||||||
|
512,
|
||||||
|
SectorSize,
|
||||||
|
(PVOID)&Bpb,
|
||||||
|
&DeviceError))
|
||||||
|
{
|
||||||
|
/* Check if it's an actual EXT2 volume */
|
||||||
|
if (FsRecIsExt2Volume(Bpb))
|
||||||
|
{
|
||||||
|
/* It is! */
|
||||||
Status = STATUS_FS_DRIVER_REQUIRED;
|
Status = STATUS_FS_DRIVER_REQUIRED;
|
||||||
}
|
}
|
||||||
break;
|
}
|
||||||
|
|
||||||
case IRP_MN_LOAD_FILE_SYSTEM:
|
/* Free the boot sector if we have one */
|
||||||
DPRINT("FAT: IRP_MN_LOAD_FILE_SYSTEM\n");
|
ExFreePool(Bpb);
|
||||||
RtlRosInitUnicodeStringFromLiteral(&RegistryPath,
|
|
||||||
L"\\Registry\\Machine\\System\\CurrentControlSet\\Services\\Ext2");
|
|
||||||
Status = ZwLoadDriver(&RegistryPath);
|
|
||||||
if (!NT_SUCCESS(Status))
|
|
||||||
{
|
|
||||||
DPRINT("ZwLoadDriver failed (Status %x)\n", Status);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
IoUnregisterFileSystem(DeviceObject);
|
/* We have some sort of failure in the storage stack */
|
||||||
|
DeviceError = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Check if we have an error on the stack */
|
||||||
|
if (DeviceError)
|
||||||
|
{
|
||||||
|
/* Was this because of a floppy? */
|
||||||
|
if (MountDevice->Characteristics & FILE_FLOPPY_DISKETTE)
|
||||||
|
{
|
||||||
|
/* Let the FS try anyway */
|
||||||
|
Status = STATUS_FS_DRIVER_REQUIRED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case IRP_MN_LOAD_FILE_SYSTEM:
|
||||||
|
|
||||||
|
/* Load the file system */
|
||||||
|
Status = FsRecLoadFileSystem(DeviceObject,
|
||||||
|
L"\\Registry\\Machine\\System\\CurrentControlSet\\Services\\Ext2");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
DPRINT("FAT: Unknown minor function %lx\n", Stack->MinorFunction);
|
|
||||||
|
/* Invalid request */
|
||||||
Status = STATUS_INVALID_DEVICE_REQUEST;
|
Status = STATUS_INVALID_DEVICE_REQUEST;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
return(Status);
|
|
||||||
|
/* Return Status */
|
||||||
|
return Status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* EOF */
|
/* EOF */
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
/* FUNCTIONS ****************************************************************/
|
/* FUNCTIONS ****************************************************************/
|
||||||
|
|
||||||
NTSTATUS
|
BOOLEAN
|
||||||
NTAPI
|
NTAPI
|
||||||
FsRecIsFatVolume(IN PPACKED_BOOT_SECTOR PackedBootSector)
|
FsRecIsFatVolume(IN PPACKED_BOOT_SECTOR PackedBootSector)
|
||||||
{
|
{
|
||||||
|
@ -163,7 +163,7 @@ FsRecVfatFsControl(IN PDEVICE_OBJECT DeviceObject,
|
||||||
|
|
||||||
/* Load the file system */
|
/* Load the file system */
|
||||||
Status = FsRecLoadFileSystem(DeviceObject,
|
Status = FsRecLoadFileSystem(DeviceObject,
|
||||||
L"\\Registry\\Machine\\System\\CurrentControlSet\\Services\\Vfatfs");
|
L"\\Registry\\Machine\\System\\CurrentControlSet\\Services\\fastfat");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -153,6 +153,12 @@ FsRecFsControl(IN PDEVICE_OBJECT DeviceObject,
|
||||||
Status = FsRecUdfsFsControl(DeviceObject, Irp);
|
Status = FsRecUdfsFsControl(DeviceObject, Irp);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case FS_TYPE_EXT2:
|
||||||
|
|
||||||
|
/* Send EXT2 command */
|
||||||
|
Status = FsRecExt2FsControl(DeviceObject, Irp);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
||||||
/* Unrecognized FS */
|
/* Unrecognized FS */
|
||||||
|
@ -359,6 +365,16 @@ DriverEntry(IN PDRIVER_OBJECT DriverObject,
|
||||||
FILE_DEVICE_DISK_FILE_SYSTEM);
|
FILE_DEVICE_DISK_FILE_SYSTEM);
|
||||||
if (NT_SUCCESS(Status)) DeviceCount++;
|
if (NT_SUCCESS(Status)) DeviceCount++;
|
||||||
|
|
||||||
|
/* Register EXT2 */
|
||||||
|
/*Status = FsRecRegisterFs(DriverObject,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
|
L"\\Ext2",
|
||||||
|
L"\\FileSystem\\Ext2Recognizer",
|
||||||
|
FS_TYPE_EXT2,
|
||||||
|
FILE_DEVICE_DISK_FILE_SYSTEM);
|
||||||
|
if (NT_SUCCESS(Status)) DeviceCount++;*/
|
||||||
|
|
||||||
/* Return appropriate Status */
|
/* Return appropriate Status */
|
||||||
return (DeviceCount > 0) ? STATUS_SUCCESS : STATUS_IMAGE_ALREADY_LOADED;
|
return (DeviceCount > 0) ? STATUS_SUCCESS : STATUS_IMAGE_ALREADY_LOADED;
|
||||||
}
|
}
|
||||||
|
|
|
@ -180,7 +180,8 @@ typedef enum _FILE_SYSTEM_TYPE
|
||||||
FS_TYPE_VFAT,
|
FS_TYPE_VFAT,
|
||||||
FS_TYPE_NTFS,
|
FS_TYPE_NTFS,
|
||||||
FS_TYPE_CDFS,
|
FS_TYPE_CDFS,
|
||||||
FS_TYPE_UDFS
|
FS_TYPE_UDFS,
|
||||||
|
FS_TYPE_EXT2,
|
||||||
} FILE_SYSTEM_TYPE, *PFILE_SYSTEM_TYPE;
|
} FILE_SYSTEM_TYPE, *PFILE_SYSTEM_TYPE;
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -234,6 +235,13 @@ FsRecUdfsFsControl(
|
||||||
IN PIRP Irp
|
IN PIRP Irp
|
||||||
);
|
);
|
||||||
|
|
||||||
|
NTSTATUS
|
||||||
|
NTAPI
|
||||||
|
FsRecExt2FsControl(
|
||||||
|
IN PDEVICE_OBJECT DeviceObject,
|
||||||
|
IN PIRP Irp
|
||||||
|
);
|
||||||
|
|
||||||
BOOLEAN
|
BOOLEAN
|
||||||
NTAPI
|
NTAPI
|
||||||
FsRecGetDeviceSectors(
|
FsRecGetDeviceSectors(
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
<library>hal</library>
|
<library>hal</library>
|
||||||
<file>blockdev.c</file>
|
<file>blockdev.c</file>
|
||||||
<file>cdfs.c</file>
|
<file>cdfs.c</file>
|
||||||
|
<file>ext2.c</file>
|
||||||
<file>fat.c</file>
|
<file>fat.c</file>
|
||||||
<file>fs_rec.c</file>
|
<file>fs_rec.c</file>
|
||||||
<file>ntfs.c</file>
|
<file>ntfs.c</file>
|
||||||
|
|
Loading…
Reference in a new issue