From 6f95c0b5815a4bd3362c1e8fe2241df25318d6fa Mon Sep 17 00:00:00 2001 From: Amlal Date: Mon, 20 Jan 2025 12:17:47 +0100 Subject: ADD: Working on a fix for the last problem on NeFS. Signed-off-by: Amlal --- dev/Kernel/src/DriveMgr.cc | 11 ++++------- dev/Kernel/src/FS/NeFS.cc | 13 +++++++++++-- dev/Kernel/src/Heap.cc | 4 ++-- 3 files changed, 17 insertions(+), 11 deletions(-) (limited to 'dev/Kernel/src') diff --git a/dev/Kernel/src/DriveMgr.cc b/dev/Kernel/src/DriveMgr.cc index 2ba48a4e..b73dfbe6 100644 --- a/dev/Kernel/src/DriveMgr.cc +++ b/dev/Kernel/src/DriveMgr.cc @@ -47,15 +47,12 @@ namespace Kernel Void io_drv_output(DriveTrait::DrivePacket* pckt) { if (!pckt) - { return; - } - if (pckt->fPacketReadOnly) - { - pckt->fPacketGood = NO; - return; - } + if (pckt->fPacketReadOnly) + return; + + kcout << "Writing blob to disk...\r"; #ifdef __AHCI__ drv_std_write(pckt->fPacketLba, (Char*)pckt->fPacketContent, pckt->fSectorSz, pckt->fPacketSize); diff --git a/dev/Kernel/src/FS/NeFS.cc b/dev/Kernel/src/FS/NeFS.cc index e375632f..0ef83615 100644 --- a/dev/Kernel/src/FS/NeFS.cc +++ b/dev/Kernel/src/FS/NeFS.cc @@ -138,13 +138,22 @@ _Output BOOL NeFileSystemParser::CreateFork(_Input NFS_FORK_STRUCT& the_fork) the_fork.PreviousSibling = lbaOfPreviousFork; the_fork.NextSibling = (the_fork.DataOffset - the_fork.DataSize - sizeof(NFS_FORK_STRUCT)); + NFS_FORK_STRUCT* fork = new NFS_FORK_STRUCT; + + MUST_PASS(fork); // ????? + + rt_copy_memory(&the_fork, fork, sizeof(NFS_FORK_STRUCT)); + drv.fPacket.fPacketLba = lba; drv.fPacket.fPacketSize = sizeof(NFS_FORK_STRUCT); - drv.fPacket.fPacketContent = &the_fork; + drv.fPacket.fPacketContent = fork; kcout << "Writing fork...\r"; - drv.fOutput(&drv.fPacket); + drv.fOutput(&drv.fPacket); + + delete fork; + fork = nullptr; /// log what we have now. kcout << "Wrote fork data at: " << hex_number(the_fork.DataOffset) diff --git a/dev/Kernel/src/Heap.cc b/dev/Kernel/src/Heap.cc index 984ffebc..7409813b 100644 --- a/dev/Kernel/src/Heap.cc +++ b/dev/Kernel/src/Heap.cc @@ -40,7 +40,7 @@ namespace Kernel struct PACKED HEAP_INFORMATION_BLOCK final { ///! @brief 32-bit value which contains the magic number of the heap. - UInt32 fMagic : 24; + UInt32 fMagic; ///! @brief Boolean value which tells if the heap is allocated. Boolean fPresent : 1; @@ -63,7 +63,7 @@ namespace Kernel /// @brief 64-bit pointer size. SizeT fHeapSize; - /// @brief 64-bit target pointer. + /// @brief 64-bit target offset pointer. UIntPtr fHeapPtr; /// @brief Padding bytes for header. -- cgit v1.2.3