diff options
| author | Amlal <amlal.elmahrouss@icloud.com> | 2025-01-20 17:53:45 +0100 |
|---|---|---|
| committer | Amlal <amlal.elmahrouss@icloud.com> | 2025-01-20 17:53:45 +0100 |
| commit | ca6831144b352e9d8fb7a514cfe717426ad6fa7b (patch) | |
| tree | 9044da1485b791676f470aceacf473fc3826bf76 | |
| parent | 6f95c0b5815a4bd3362c1e8fe2241df25318d6fa (diff) | |
ADD: SwapDisk format, you use a custom data structure to work with virtual memory now.
Signed-off-by: Amlal <amlal.elmahrouss@icloud.com>
| -rw-r--r-- | dev/Kernel/HALKit/AMD64/HalDebugOutput.cc | 8 | ||||
| -rw-r--r-- | dev/Kernel/HALKit/AMD64/HalSchedulerCorePrimitivesAMD64.cc | 4 | ||||
| -rw-r--r-- | dev/Kernel/HALKit/ARM64/HalSchedulerCorePrimitivesARM64.cc | 4 | ||||
| -rw-r--r-- | dev/Kernel/KernelKit/FileMgr.h | 2 | ||||
| -rw-r--r-- | dev/Kernel/SystemKit/SwapDisk.h | 19 | ||||
| -rw-r--r-- | dev/Kernel/src/DriveMgr.cc | 6 | ||||
| -rw-r--r-- | dev/Kernel/src/FS/NeFS.cc | 12 | ||||
| -rw-r--r-- | dev/Kernel/src/HardwareThreadScheduler.cc | 2 | ||||
| -rw-r--r-- | dev/Kernel/src/Heap.cc | 2 | ||||
| -rw-r--r-- | dev/Kernel/src/System/SwapDisk.cc | 11 |
10 files changed, 43 insertions, 27 deletions
diff --git a/dev/Kernel/HALKit/AMD64/HalDebugOutput.cc b/dev/Kernel/HALKit/AMD64/HalDebugOutput.cc index 85838ecf..371f344c 100644 --- a/dev/Kernel/HALKit/AMD64/HalDebugOutput.cc +++ b/dev/Kernel/HALKit/AMD64/HalDebugOutput.cc @@ -21,15 +21,15 @@ namespace Kernel namespace Detail { - constexpr Int16 kPort = 0x3F8; - static Int32 kState = kStateInvalid; + constexpr Int16 kPort = 0x3F8; + static Int32 kState = kStateInvalid; /// @brief Init COM1. /// @return - template <Int16 PORT> + template <Int16 PORT> bool hal_serial_init() noexcept { - if (kState == kStateReady || kState == kStateTransmit) + if (kState == kStateReady || kState == kStateTransmit) return true; HAL::rt_out8(PORT + 1, 0x00); // Disable all interrupts diff --git a/dev/Kernel/HALKit/AMD64/HalSchedulerCorePrimitivesAMD64.cc b/dev/Kernel/HALKit/AMD64/HalSchedulerCorePrimitivesAMD64.cc index 5eee0245..601ac002 100644 --- a/dev/Kernel/HALKit/AMD64/HalSchedulerCorePrimitivesAMD64.cc +++ b/dev/Kernel/HALKit/AMD64/HalSchedulerCorePrimitivesAMD64.cc @@ -16,8 +16,8 @@ namespace Kernel EXTERN_C Void __zka_pure_call(UserProcess* process) { - if (process) - process->Crash(); + if (process) + process->Crash(); } /***********************************************************************************/ diff --git a/dev/Kernel/HALKit/ARM64/HalSchedulerCorePrimitivesARM64.cc b/dev/Kernel/HALKit/ARM64/HalSchedulerCorePrimitivesARM64.cc index e46c4b66..ed2ffdb8 100644 --- a/dev/Kernel/HALKit/ARM64/HalSchedulerCorePrimitivesARM64.cc +++ b/dev/Kernel/HALKit/ARM64/HalSchedulerCorePrimitivesARM64.cc @@ -16,8 +16,8 @@ namespace Kernel EXTERN_C Void __zka_pure_call(UserProcess* process)
{
- if (process)
- process->Crash();
+ if (process)
+ process->Crash();
}
/***********************************************************************************/
diff --git a/dev/Kernel/KernelKit/FileMgr.h b/dev/Kernel/KernelKit/FileMgr.h index f735e8c3..830c0baf 100644 --- a/dev/Kernel/KernelKit/FileMgr.h +++ b/dev/Kernel/KernelKit/FileMgr.h @@ -14,7 +14,7 @@ 31/01/24: Update documentation (amlel) 05/07/24: NeFS support, and fork support, updated constants and specs as well. - 18/01/25: Patches to FileStream class. + 18/01/25: Patches to FileStream class. ------------------------------------------- */ diff --git a/dev/Kernel/SystemKit/SwapDisk.h b/dev/Kernel/SystemKit/SwapDisk.h index 07d3cb73..eee7fdef 100644 --- a/dev/Kernel/SystemKit/SwapDisk.h +++ b/dev/Kernel/SystemKit/SwapDisk.h @@ -18,6 +18,8 @@ namespace Kernel { + struct SWAP_DISK_HEADER; + /// @brief This class is a disk swap delegate for any data. available as a syscall too. class SwapDisk final { @@ -27,7 +29,20 @@ namespace Kernel ZKA_COPY_DEFAULT(SwapDisk); - BOOL Write(const Char* fork_name, const SizeT fork_name_len, VoidPtr data, const SizeT data_len); - VoidPtr Read(const Char* fork_name, const SizeT fork_name_len, const SizeT data_len); + BOOL Write(const Char* fork_name, const SizeT fork_name_len, SWAP_DISK_HEADER* data, const SizeT data_len); + SWAP_DISK_HEADER* Read(const Char* fork_name, const SizeT fork_name_len, const SizeT data_len); }; + + typedef struct SWAP_DISK_HEADER + { + UInt32 fMagic; + SizeT fHeaderSz; + UInt64 fTeamID; + UInt64 fProcessID; + UInt64 fVirtualAddress; + SizeT fBlobSz; + Char fBlob[]; + } PACKED SWAP_DISK_HEADER; + + typedef SWAP_DISK_HEADER* SWAP_DISK_HEADER_REF; } // namespace Kernel diff --git a/dev/Kernel/src/DriveMgr.cc b/dev/Kernel/src/DriveMgr.cc index b73dfbe6..eea53bc6 100644 --- a/dev/Kernel/src/DriveMgr.cc +++ b/dev/Kernel/src/DriveMgr.cc @@ -49,10 +49,10 @@ namespace Kernel if (!pckt) return; - if (pckt->fPacketReadOnly) - return; + if (pckt->fPacketReadOnly) + return; - kcout << "Writing blob to disk...\r"; + 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 0ef83615..213fb8c7 100644 --- a/dev/Kernel/src/FS/NeFS.cc +++ b/dev/Kernel/src/FS/NeFS.cc @@ -138,11 +138,11 @@ _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; + NFS_FORK_STRUCT* fork = new NFS_FORK_STRUCT; - MUST_PASS(fork); // ????? + MUST_PASS(fork); // ????? - rt_copy_memory(&the_fork, fork, sizeof(NFS_FORK_STRUCT)); + rt_copy_memory(&the_fork, fork, sizeof(NFS_FORK_STRUCT)); drv.fPacket.fPacketLba = lba; drv.fPacket.fPacketSize = sizeof(NFS_FORK_STRUCT); @@ -150,10 +150,10 @@ _Output BOOL NeFileSystemParser::CreateFork(_Input NFS_FORK_STRUCT& the_fork) kcout << "Writing fork...\r"; - drv.fOutput(&drv.fPacket); + drv.fOutput(&drv.fPacket); - delete fork; - fork = nullptr; + 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/HardwareThreadScheduler.cc b/dev/Kernel/src/HardwareThreadScheduler.cc index 2121a911..90f084c6 100644 --- a/dev/Kernel/src/HardwareThreadScheduler.cc +++ b/dev/Kernel/src/HardwareThreadScheduler.cc @@ -21,7 +21,7 @@ namespace Kernel /// @note Those symbols are needed in order to switch and validate the stack. /***********************************************************************************/ - EXTERN_C Bool hal_check_stack(HAL::StackFramePtr frame_ptr); + EXTERN_C Bool hal_check_stack(HAL::StackFramePtr frame_ptr); EXTERN_C Bool mp_register_process(HAL::StackFramePtr frame, ProcessID pid); STATIC HardwareThreadScheduler kHardwareThreadScheduler; diff --git a/dev/Kernel/src/Heap.cc b/dev/Kernel/src/Heap.cc index 7409813b..2e0127d6 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; + UInt64 fMagic; ///! @brief Boolean value which tells if the heap is allocated. Boolean fPresent : 1; diff --git a/dev/Kernel/src/System/SwapDisk.cc b/dev/Kernel/src/System/SwapDisk.cc index ce80ce66..798a3f2a 100644 --- a/dev/Kernel/src/System/SwapDisk.cc +++ b/dev/Kernel/src/System/SwapDisk.cc @@ -9,7 +9,7 @@ namespace Kernel { - BOOL SwapDisk::Write(const Char* fork_name, const SizeT fork_name_len, VoidPtr data, const SizeT data_len) + BOOL SwapDisk::Write(const Char* fork_name, const SizeT fork_name_len, SWAP_DISK_HEADER_REF data, const SizeT data_len) { if (!fork_name || !fork_name_len) return NO; @@ -22,7 +22,7 @@ namespace Kernel FileStream file(kSwapPageFile, "wb"); - auto ret = file.Write(fork_name, data, data_len); + auto ret = file.Write(fork_name, data, sizeof(SWAP_DISK_HEADER) + data_len); if (ret.Error()) return NO; @@ -30,7 +30,7 @@ namespace Kernel return YES; } - VoidPtr SwapDisk::Read(const Char* fork_name, const SizeT fork_name_len, const SizeT data_len) + SWAP_DISK_HEADER_REF SwapDisk::Read(const Char* fork_name, const SizeT fork_name_len, const SizeT data_len) { if (!fork_name || !fork_name_len) return nullptr; @@ -40,7 +40,8 @@ namespace Kernel FileStream file(kSwapPageFile, "rb"); - VoidPtr blob = file.Read(fork_name, data_len); - return blob; + VoidPtr blob = file.Read(fork_name, sizeof(SWAP_DISK_HEADER) + data_len); + + return (SWAP_DISK_HEADER_REF)blob; } } // namespace Kernel |
