3 * Copyright (C) 2002, 2003 ReactOS Team
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20 * COPYRIGHT: See COPYING in the top level directory
21 * PROJECT: ReactOS kernel
22 * FILE: drivers/filesystems/cdfs/cdfs.c
23 * PURPOSE: CDROM (ISO 9660) filesystem driver
24 * PROGRAMMER: Art Yerkes
28 /* INCLUDES *****************************************************************/
35 #if defined(ALLOC_PRAGMA)
36 #pragma alloc_text(INIT, DriverEntry)
39 /* GLOBALS ******************************************************************/
41 PCDFS_GLOBAL_DATA CdfsGlobalData
;
44 /* FUNCTIONS ****************************************************************/
48 DriverEntry(PDRIVER_OBJECT DriverObject
,
49 PUNICODE_STRING RegistryPath
)
51 * FUNCTION: Called by the system to initialize the driver
53 * DriverObject = object describing this driver
54 * RegistryPath = path to our configuration entries
55 * RETURNS: Success or failure
59 PDEVICE_OBJECT CdFsDeviceObject
;
60 PDEVICE_OBJECT HddFsDeviceObject
;
61 UNICODE_STRING CdFsDeviceName
= RTL_CONSTANT_STRING(L
"\\Cdfs");
62 UNICODE_STRING HddFsDeviceName
= RTL_CONSTANT_STRING(L
"\\CdfsHdd");
64 UNREFERENCED_PARAMETER(RegistryPath
);
66 DPRINT("CDFS 0.0.3\n");
68 Status
= IoCreateDevice(DriverObject
,
69 sizeof(CDFS_GLOBAL_DATA
),
71 FILE_DEVICE_CD_ROM_FILE_SYSTEM
,
75 if (!NT_SUCCESS(Status
))
80 Status
= IoCreateDevice(DriverObject
,
83 FILE_DEVICE_DISK_FILE_SYSTEM
,
87 if (!NT_SUCCESS(Status
))
92 /* Initialize global data */
93 CdfsGlobalData
= CdFsDeviceObject
->DeviceExtension
;
94 RtlZeroMemory(CdfsGlobalData
,
95 sizeof(CDFS_GLOBAL_DATA
));
96 CdfsGlobalData
->DriverObject
= DriverObject
;
97 CdfsGlobalData
->CdFsDeviceObject
= CdFsDeviceObject
;
98 CdfsGlobalData
->HddFsDeviceObject
= HddFsDeviceObject
;
99 HddFsDeviceObject
->DeviceExtension
= CdfsGlobalData
;
101 /* Initialize driver data */
102 DriverObject
->MajorFunction
[IRP_MJ_CLOSE
] = CdfsFsdDispatch
;
103 DriverObject
->MajorFunction
[IRP_MJ_CLEANUP
] = CdfsFsdDispatch
;
104 DriverObject
->MajorFunction
[IRP_MJ_CREATE
] = CdfsFsdDispatch
;
105 DriverObject
->MajorFunction
[IRP_MJ_READ
] = CdfsFsdDispatch
;
106 DriverObject
->MajorFunction
[IRP_MJ_WRITE
] = CdfsFsdDispatch
;
107 DriverObject
->MajorFunction
[IRP_MJ_FILE_SYSTEM_CONTROL
] = CdfsFsdDispatch
;
108 DriverObject
->MajorFunction
[IRP_MJ_DIRECTORY_CONTROL
] = CdfsFsdDispatch
;
109 DriverObject
->MajorFunction
[IRP_MJ_QUERY_INFORMATION
] = CdfsFsdDispatch
;
110 DriverObject
->MajorFunction
[IRP_MJ_SET_INFORMATION
] = CdfsFsdDispatch
;
111 DriverObject
->MajorFunction
[IRP_MJ_QUERY_VOLUME_INFORMATION
] = CdfsFsdDispatch
;
112 DriverObject
->MajorFunction
[IRP_MJ_SET_VOLUME_INFORMATION
] = CdfsFsdDispatch
;
113 DriverObject
->MajorFunction
[IRP_MJ_DEVICE_CONTROL
] = CdfsFsdDispatch
;
114 DriverObject
->MajorFunction
[IRP_MJ_LOCK_CONTROL
] = CdfsFsdDispatch
;
116 CdfsGlobalData
->FastIoDispatch
.SizeOfFastIoDispatch
= sizeof(FAST_IO_DISPATCH
);
117 CdfsGlobalData
->FastIoDispatch
.FastIoCheckIfPossible
= CdfsFastIoCheckIfPossible
;
118 CdfsGlobalData
->FastIoDispatch
.FastIoRead
= CdfsFastIoRead
;
119 CdfsGlobalData
->FastIoDispatch
.FastIoWrite
= CdfsFastIoWrite
;
120 DriverObject
->FastIoDispatch
= &CdfsGlobalData
->FastIoDispatch
;
122 /* Initialize lookaside list for IRP contexts */
123 ExInitializeNPagedLookasideList(&CdfsGlobalData
->IrpContextLookasideList
,
124 NULL
, NULL
, 0, sizeof(CDFS_IRP_CONTEXT
), 'PRIC', 0);
126 DriverObject
->DriverUnload
= NULL
;
129 CdfsGlobalData
->CacheMgrCallbacks
.AcquireForLazyWrite
= CdfsAcquireForLazyWrite
;
130 CdfsGlobalData
->CacheMgrCallbacks
.ReleaseFromLazyWrite
= CdfsReleaseFromLazyWrite
;
131 CdfsGlobalData
->CacheMgrCallbacks
.AcquireForReadAhead
= CdfsAcquireForLazyWrite
;
132 CdfsGlobalData
->CacheMgrCallbacks
.ReleaseFromReadAhead
= CdfsReleaseFromLazyWrite
;
134 CdFsDeviceObject
->Flags
|= DO_DIRECT_IO
| DO_LOW_PRIORITY_FILESYSTEM
;
135 HddFsDeviceObject
->Flags
|= DO_DIRECT_IO
| DO_LOW_PRIORITY_FILESYSTEM
;
137 IoRegisterFileSystem(CdFsDeviceObject
);
138 IoRegisterFileSystem(HddFsDeviceObject
);
140 return(STATUS_SUCCESS
);