From 3a8cea6f83b7903159d61d9523f33c75b761b746 Mon Sep 17 00:00:00 2001 From: ergo720 <45463469+ergo720@users.noreply.github.com> Date: Tue, 13 Aug 2024 03:27:21 +0200 Subject: [PATCH] Fixed an issue where the fatx and xiso drivers were accidentally closing the device handles --- nboxkrnl/io/cdrom/xiso.cpp | 21 ++++++++++++--------- nboxkrnl/io/hdd/fatx.cpp | 23 +++++++++++++---------- 2 files changed, 25 insertions(+), 19 deletions(-) diff --git a/nboxkrnl/io/cdrom/xiso.cpp b/nboxkrnl/io/cdrom/xiso.cpp index a1454db..14d8bcb 100644 --- a/nboxkrnl/io/cdrom/xiso.cpp +++ b/nboxkrnl/io/cdrom/xiso.cpp @@ -434,15 +434,18 @@ static NTSTATUS XBOXAPI XisoIrpClose(PDEVICE_OBJECT DeviceObject, PIRP Irp) PXISO_FILE_INFO FileInfo = (PXISO_FILE_INFO)FileObject->FsContext2; if (--FileInfo->RefCounter == 0) { - SubmitIoRequestToHost( - DEV_TYPE(DEV_CDROM) | IoRequestType::Close, - 0, - 0, - 0, - FileInfo->HostHandle - ); - XisoRemoveFile(VolumeExtension, FileInfo); - if (!(FileInfo->Flags & XISO_VOLUME_FILE)) { + if (FileInfo->Flags & XISO_VOLUME_FILE) { + XisoRemoveFile(VolumeExtension, FileInfo); + } + else { + SubmitIoRequestToHost( + DEV_TYPE(DEV_CDROM) | IoRequestType::Close, + 0, + 0, + 0, + FileInfo->HostHandle + ); + XisoRemoveFile(VolumeExtension, FileInfo); ExFreePool(FileInfo); } FileObject->FsContext2 = nullptr; diff --git a/nboxkrnl/io/hdd/fatx.cpp b/nboxkrnl/io/hdd/fatx.cpp index 794d6da..28e19ed 100644 --- a/nboxkrnl/io/hdd/fatx.cpp +++ b/nboxkrnl/io/hdd/fatx.cpp @@ -608,15 +608,18 @@ static NTSTATUS XBOXAPI FatxIrpClose(PDEVICE_OBJECT DeviceObject, PIRP Irp) // NOTE: it's not viable to check for FileInfo->ShareAccess.OpenCount here, because it's possible to use a file handle with no access rights granted, which would // mean that OpenCount is zero and yet the handle is still in use if (--FileInfo->RefCounter == 0) { - SubmitIoRequestToHost( - DEV_TYPE(VolumeExtension->CacheExtension.DeviceType) | IoRequestType::Close, - 0, - 0, - 0, - FileInfo->HostHandle - ); - FatxRemoveFile(VolumeExtension, FileInfo); - if (!(FileInfo->Flags & FATX_VOLUME_FILE)) { + if (FileInfo->Flags & FATX_VOLUME_FILE) { + FatxRemoveFile(VolumeExtension, FileInfo); + } + else { + SubmitIoRequestToHost( + DEV_TYPE(VolumeExtension->CacheExtension.DeviceType) | IoRequestType::Close, + 0, + 0, + 0, + FileInfo->HostHandle + ); + FatxRemoveFile(VolumeExtension, FileInfo); ExFreePool(FileInfo); } FileObject->FsContext2 = nullptr; @@ -796,7 +799,7 @@ static NTSTATUS XBOXAPI FatxIrpWrite(PDEVICE_OBJECT DeviceObject, PIRP Irp) } else if (NT_SUCCESS(Status)) { if ((FileObject->CurrentByteOffset.LowPart + InfoBlock.Info) > FileInfo->FileSize) { - FileInfo->FileSize = FileObject->CurrentByteOffset.QuadPart + InfoBlock.Info; + FileInfo->FileSize = FileObject->CurrentByteOffset.LowPart + InfoBlock.Info; } if (FileObject->Flags & FO_SYNCHRONOUS_IO) { FileObject->CurrentByteOffset.QuadPart += InfoBlock.Info;