summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorAmlal <amlal.elmahrouss@icloud.com>2025-01-20 17:53:45 +0100
committerAmlal <amlal.elmahrouss@icloud.com>2025-01-20 17:53:45 +0100
commitca6831144b352e9d8fb7a514cfe717426ad6fa7b (patch)
tree9044da1485b791676f470aceacf473fc3826bf76
parent6f95c0b5815a4bd3362c1e8fe2241df25318d6fa (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.cc8
-rw-r--r--dev/Kernel/HALKit/AMD64/HalSchedulerCorePrimitivesAMD64.cc4
-rw-r--r--dev/Kernel/HALKit/ARM64/HalSchedulerCorePrimitivesARM64.cc4
-rw-r--r--dev/Kernel/KernelKit/FileMgr.h2
-rw-r--r--dev/Kernel/SystemKit/SwapDisk.h19
-rw-r--r--dev/Kernel/src/DriveMgr.cc6
-rw-r--r--dev/Kernel/src/FS/NeFS.cc12
-rw-r--r--dev/Kernel/src/HardwareThreadScheduler.cc2
-rw-r--r--dev/Kernel/src/Heap.cc2
-rw-r--r--dev/Kernel/src/System/SwapDisk.cc11
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