summaryrefslogtreecommitdiffhomepage
path: root/dev/boot/modules
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal.elmahrouss@icloud.com>2025-03-23 19:52:25 +0100
committerAmlal El Mahrouss <amlal.elmahrouss@icloud.com>2025-03-23 19:52:25 +0100
commit5870e529d9f788588836a9dc9fe8b4f026bfe984 (patch)
treee1d4d2f6ebb9df367e6b277b9a0f7584aece0e37 /dev/boot/modules
parent328487312fbbeb7a2cdf0b5508c74a43cdb5d499 (diff)
kernel(fix): Last fixes in order to build NeKernel, and fix CI.
Signed-off-by: Amlal El Mahrouss <amlal.elmahrouss@icloud.com>
Diffstat (limited to 'dev/boot/modules')
-rw-r--r--dev/boot/modules/.keep0
-rw-r--r--dev/boot/modules/NetBoot/.hgkeep0
-rw-r--r--dev/boot/modules/NetBoot/Boot.S28
-rw-r--r--dev/boot/modules/NetBoot/NetBoot.cc44
-rw-r--r--dev/boot/modules/NetBoot/NetBoot.h33
-rw-r--r--dev/boot/modules/NetBoot/build.json24
-rw-r--r--dev/boot/modules/SysChk/.hgkeep0
-rw-r--r--dev/boot/modules/SysChk/Boot.S22
-rw-r--r--dev/boot/modules/SysChk/Module.cc36
-rw-r--r--dev/boot/modules/SysChk/amd64.json24
-rw-r--r--dev/boot/modules/SysChk/arm64.json26
11 files changed, 237 insertions, 0 deletions
diff --git a/dev/boot/modules/.keep b/dev/boot/modules/.keep
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/dev/boot/modules/.keep
diff --git a/dev/boot/modules/NetBoot/.hgkeep b/dev/boot/modules/NetBoot/.hgkeep
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/dev/boot/modules/NetBoot/.hgkeep
diff --git a/dev/boot/modules/NetBoot/Boot.S b/dev/boot/modules/NetBoot/Boot.S
new file mode 100644
index 00000000..2095b91d
--- /dev/null
+++ b/dev/boot/modules/NetBoot/Boot.S
@@ -0,0 +1,28 @@
+;; /*
+;; * ========================================================
+;; *
+;; * BootZ
+;; * Copyright (C) 2024-2025, Amlal EL Mahrouss, all rights reserved.
+;; *
+;; * ========================================================
+;; */
+
+.code64
+.intel_syntax noprefix
+
+#define kTypeDriver 101
+#define kArchAmd64 122
+#define kHandoverMagic 0xBADCC
+
+.section .ldr
+
+.quad kHandoverMagic
+.word kTypeDriver
+
+.text
+
+.extern main
+.global __main
+
+__main:
+ ret
diff --git a/dev/boot/modules/NetBoot/NetBoot.cc b/dev/boot/modules/NetBoot/NetBoot.cc
new file mode 100644
index 00000000..16a9ae1e
--- /dev/null
+++ b/dev/boot/modules/NetBoot/NetBoot.cc
@@ -0,0 +1,44 @@
+/*
+ * ========================================================
+ *
+ * NetBoot
+ * Copyright (C) 2024-2025, Amlal EL Mahrouss, all rights reserved.
+ *
+ * ========================================================
+ */
+
+#include <modules/NetBoot/NetBoot.h>
+#include <BootKit/BootKit.h>
+#include <BootKit/BootThread.h>
+
+EXTERN_C Int32 ModuleMain(NeOS::HEL::BootInfoHeader* handover)
+{
+ NETBOOT_INTERNET_HEADER inet{};
+
+ /// TODO: Read Packet from localhost
+
+ if (inet.PatchLength < 0)
+ {
+ Boot::BootTextWriter writer;
+ writer.Write("NetBootLauncher: No Patch attached to packet.\r");
+
+ return kEfiFail;
+ }
+
+ if (!inet.EEPROM)
+ {
+ Boot::BootThread thread(inet.Data);
+
+ if (thread.IsValid())
+ return thread.Start(handover, YES);
+ }
+ else
+ {
+ Boot::BootTextWriter writer;
+ writer.Write("NetBootLauncher: EEPROM flash not available for now.\r");
+
+ return kEfiFail; // TODO: Add support for EEPROM firmware update.
+ }
+
+ return kEfiFail;
+}
diff --git a/dev/boot/modules/NetBoot/NetBoot.h b/dev/boot/modules/NetBoot/NetBoot.h
new file mode 100644
index 00000000..aeeaf18b
--- /dev/null
+++ b/dev/boot/modules/NetBoot/NetBoot.h
@@ -0,0 +1,33 @@
+/*
+ * ========================================================
+ *
+ * NetBoot
+ * Copyright (C) 2024-2025, Amlal EL Mahrouss, all rights reserved.
+ *
+ * ========================================================
+ */
+
+#pragma once
+
+#include <NewKit/Defines.h>
+
+#define kNetBootINetMagic "NETB"
+#define kNetBootINetMagicLength (4)
+
+#define kNetBootNameLen (256U)
+
+/// @brief the internet header is used to download updates OTA.
+typedef struct NETBOOT_INTERNET_HEADER
+{
+ NeOS::Char NB1; /// magic char 1 'N'
+ NeOS::Char NB2; /// magic char 2 'E'
+ NeOS::Char NB3; /// magic char 3 'T'
+ NeOS::Char NB4; /// magic char 4 'B'
+
+ NeOS::Char PatchName[kNetBootNameLen]; /// example: Modjo
+ NeOS::Int32 PatchLength; /// the patch length.
+ NeOS::Char PatchTarget[kNetBootNameLen]; /// the target file.
+ NeOS::Boolean EEPROM : 1; /// does it imply an EEPROM reprogram?
+ NeOS::Boolean Preflight : 1; /// is it a preflight packet.
+ NeOS::Char Data[]; /// non preflight packet has a patch blob for a **PatchTarget**
+} ATTRIBUTE(packed) NETBOOT_INTERNET_HEADER;
diff --git a/dev/boot/modules/NetBoot/build.json b/dev/boot/modules/NetBoot/build.json
new file mode 100644
index 00000000..2c92567d
--- /dev/null
+++ b/dev/boot/modules/NetBoot/build.json
@@ -0,0 +1,24 @@
+{
+ "compiler_path": "x86_64-w64-mingw32-g++",
+ "compiler_std": "c++20",
+ "headers_path": ["../", "../../", "../../../kernel", "../../../", "./"],
+ "sources_path": [".cc", "*.S"],
+ "output_name": "netboot.sys",
+ "compiler_flags": [
+ "-ffreestanding",
+ "-nostdlib",
+ "-std=c++20",
+ "-fPIC",
+ "-fno-rtti",
+ "-fno-exceptions",
+ "-Wl,--subsystem=17,--image-base,0x10000000,-e,ModuleMain"
+ ],
+ "cpp_macros": [
+ "__NEOSKRNL__",
+ "__BOOTZ__",
+ "__NE_AMD64__",
+ "kNetBootVersionHighest=0x0100",
+ "kNetBootVersionLowest=0x0100",
+ "kNetBootVersion=0x0100"
+ ]
+}
diff --git a/dev/boot/modules/SysChk/.hgkeep b/dev/boot/modules/SysChk/.hgkeep
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/dev/boot/modules/SysChk/.hgkeep
diff --git a/dev/boot/modules/SysChk/Boot.S b/dev/boot/modules/SysChk/Boot.S
new file mode 100644
index 00000000..8ebfb352
--- /dev/null
+++ b/dev/boot/modules/SysChk/Boot.S
@@ -0,0 +1,22 @@
+;; /*
+;; * ========================================================
+;; *
+;; * BootZ
+;; * Copyright (C) 2024-2025, Amlal EL Mahrouss, all rights reserved.
+;; *
+;; * ========================================================
+;; */
+
+#ifdef __NE_AMD64__
+.code64
+.intel_syntax noprefix
+#endif
+
+#define kTypeDriver 101
+#define kArchAmd64 122
+#define kHandoverMagic 0xBADCC
+
+.section .ldr
+
+.quad kHandoverMagic
+.word kTypeDriver
diff --git a/dev/boot/modules/SysChk/Module.cc b/dev/boot/modules/SysChk/Module.cc
new file mode 100644
index 00000000..c22e183b
--- /dev/null
+++ b/dev/boot/modules/SysChk/Module.cc
@@ -0,0 +1,36 @@
+/*
+ * ========================================================
+ *
+ * NetBoot
+ * Copyright (C) 2024-2025, Amlal EL Mahrouss, all rights reserved.
+ *
+ * ========================================================
+ */
+
+#include <BootKit/BootKit.h>
+#include <modules/CoreGfx/FBMgr.h>
+#include <modules/CoreGfx/TextMgr.h>
+#include <FirmwareKit/EFI.h>
+#include <FirmwareKit/EFI/API.h>
+#include <FirmwareKit/Handover.h>
+#include <KernelKit/MSDOS.h>
+#include <KernelKit/PE.h>
+#include <KernelKit/PEF.h>
+#include <NewKit/Macros.h>
+#include <NewKit/Ref.h>
+#include <BootKit/BootThread.h>
+#include <modules/CoreGfx/FBMgr.h>
+
+EXTERN_C Int32 ModuleMain(NeOS::HEL::BootInfoHeader* handover)
+{
+#ifdef __NE_AMD64__
+ Boot::BDiskFormatFactory<BootDeviceATA> partition_factory;
+
+ if (partition_factory.IsPartitionValid())
+ return kEfiOk;
+
+ return kEfiFail;
+#else
+ return kEfiOk;
+#endif
+}
diff --git a/dev/boot/modules/SysChk/amd64.json b/dev/boot/modules/SysChk/amd64.json
new file mode 100644
index 00000000..97b6c418
--- /dev/null
+++ b/dev/boot/modules/SysChk/amd64.json
@@ -0,0 +1,24 @@
+{
+ "compiler_path": "x86_64-w64-mingw32-g++",
+ "compiler_std": "c++20",
+ "headers_path": ["../", "../../", "../../../kernel", "../../../", "./"],
+ "sources_path": ["*.cc", "*.S", "../../src/HEL/AMD64/*.cc", "../../src/HEL/AMD64/*.S", "../../src/*.cc"],
+ "output_name": "syschk.sys",
+ "compiler_flags": [
+ "-nostdlib",
+ "-std=c++20",
+ "-fPIC",
+ "-fno-rtti",
+ "-fno-exceptions",
+ "-Wl,--subsystem=17,--image-base,0x10000000,-e,ModuleMain"
+ ],
+ "cpp_macros": [
+ "__NEOSKRNL__",
+ "__BOOTZ__",
+ "__BOOTLDR_STANDALONE__",
+ "__NE_AMD64__",
+ "kChkVersionHighest=0x0100",
+ "kChkVersionLowest=0x0100",
+ "kChkVersion=0x0100"
+ ]
+}
diff --git a/dev/boot/modules/SysChk/arm64.json b/dev/boot/modules/SysChk/arm64.json
new file mode 100644
index 00000000..6d9161ea
--- /dev/null
+++ b/dev/boot/modules/SysChk/arm64.json
@@ -0,0 +1,26 @@
+{
+ "compiler_path": "clang++",
+ "compiler_std": "c++20",
+ "headers_path": ["../", "../../", "../../../kernel", "../../../", "./"],
+ "sources_path": ["*.cc", "*.S", "../../src/HEL/ARM64/*.cc", "../../src/HEL/ARM64/*.S", "../../src/*.cc"],
+ "output_name": "syschk.sys",
+ "compiler_flags": [
+ "-ffreestanding",
+ "-nostdlib",
+ "-std=c++20",
+ "-fno-rtti",
+ "-fno-exceptions",
+ "-fuse-ld=lld",
+ "-Wl,-subsystem:efi_application,-entry:ModuleMain",
+ "-target aarch64-unknown-windows"
+ ],
+ "cpp_macros": [
+ "__NEOSKRNL__",
+ "__BOOTZ__",
+ "__BOOTLDR_STANDALONE__",
+ "__NE_ARM64__",
+ "kChkVersionHighest=0x0100",
+ "kChkVersionLowest=0x0100",
+ "kChkVersion=0x0100"
+ ]
+}