diff options
| author | Amlal El Mahrouss <amlal.elmahrouss@icloud.com> | 2024-04-26 08:13:03 +0200 |
|---|---|---|
| committer | Amlal El Mahrouss <amlal.elmahrouss@icloud.com> | 2024-04-26 08:13:03 +0200 |
| commit | 3b4a4a290b32fdb4a749b3e581afae450eb543c8 (patch) | |
| tree | fc9278f51212e73f75f02942ad05abfaee64ca68 | |
| parent | 9679735cb60011490c92fd8d3b13d337120a22ea (diff) | |
MHR-16: NewBoot - BDiskFormatter and QR.
Signed-off-by: Amlal El Mahrouss <amlal.elmahrouss@icloud.com>
| -rw-r--r-- | Private/FSKit/NewFS.hxx | 9 | ||||
| -rw-r--r-- | Private/HALKit/AMD64/HalNewBoot.asm | 14 | ||||
| -rw-r--r-- | Private/HALKit/AMD64/Storage/ATA-PIO.cxx | 2 | ||||
| -rw-r--r-- | Private/HALKit/POWER/HalStartSequence.s | 8 | ||||
| -rw-r--r-- | Private/Linker/16x0.json | 2 | ||||
| -rw-r--r-- | Private/Linker/32x0.json | 2 | ||||
| -rw-r--r-- | Private/Linker/64x0.json | 2 | ||||
| -rw-r--r-- | Private/NewBoot/BootKit/BootKit.hxx | 149 | ||||
| -rw-r--r-- | Private/NewBoot/BootKit/HW/ATA.hxx | 2 | ||||
| -rw-r--r-- | Private/NewBoot/Source/HEL/AMD64/BootATA.cxx | 26 | ||||
| -rw-r--r-- | Private/NewBoot/Source/HEL/AMD64/BootJump.S | 9 | ||||
| -rw-r--r-- | Private/NewBoot/Source/HEL/AMD64/BootMain.cxx | 94 | ||||
| -rw-r--r-- | Private/NewBoot/Source/HEL/AMD64/BootTextWriter.cxx | 2 | ||||
| -rw-r--r-- | Private/NewBoot/Source/HEL/AMD64/New+Delete.cxx | 11 | ||||
| -rw-r--r-- | Private/NewBoot/Source/makefile | 13 | ||||
| -rw-r--r-- | Private/NewLoader/ReadMe.md | 9 | ||||
| -rw-r--r-- | Private/NewLoader/Source/.gitkeep | 0 | ||||
| -rw-r--r-- | Private/makefile | 10 |
18 files changed, 253 insertions, 111 deletions
diff --git a/Private/FSKit/NewFS.hxx b/Private/FSKit/NewFS.hxx index cc43f51b..d3b72803 100644 --- a/Private/FSKit/NewFS.hxx +++ b/Private/FSKit/NewFS.hxx @@ -38,7 +38,7 @@ default. #define kNewFSIdentLen 8 #define kNewFSIdent " NewFS" -#define kNewFSPadLen 16 +#define kNewFSPadLen 408 /// @brief Partition GUID on EPM and GPT disks. #define kNewFSUUID "@{DD997393-9CCE-4288-A8D5-C0FDE3908DBE}" @@ -83,6 +83,7 @@ default. /// Start After the PM headers, pad 1024 bytes. #define kNewFSAddressAsLba (1024) +#define kNewFSCatalogStartAddress (kNewFSAddressAsLba + sizeof(NewPartitionBlock)) #define kResourceTypeDialog 10 #define kResourceTypeString 11 @@ -139,6 +140,9 @@ struct PACKED NewFork final { NewOS::Lba NextSibling; NewOS::Lba PreviousSibling; + + /// To make a perfect sector. + NewOS::Char Padding[200]; }; /// @brief Partition block type @@ -174,6 +178,9 @@ enum { kNewFSSubDriveCount, }; +/// \brief Resource fork kind. +enum { kNewFSRsrcForkKind = 0, kNewFSDataForkKind = 1 }; + /// /// \name NewFSParser /// \brief NewFS parser class. (catalog creation, remove removal, root, diff --git a/Private/HALKit/AMD64/HalNewBoot.asm b/Private/HALKit/AMD64/HalNewBoot.asm index 995a848c..11b11c0c 100644 --- a/Private/HALKit/AMD64/HalNewBoot.asm +++ b/Private/HALKit/AMD64/HalNewBoot.asm @@ -23,22 +23,16 @@ HandoverMagic: dq kHandoverMagic HandoverType: dw kTypeKernel HandoverArch: dw kArchAmd64 ;; This NewBootStart points to Main. -HandoverStart: dq Main +HandoverStart: dq __ImageStart section .text -global Main +global __ImageStart extern hal_init_platform ;; Just a simple setup, we'd also need to tell some before -Main: - push rax +__ImageStart: push rcx call hal_init_platform pop rcx - pop rax -;; Go to sleep. -MainLoop: - cli - hlt - jmp $ + ret diff --git a/Private/HALKit/AMD64/Storage/ATA-PIO.cxx b/Private/HALKit/AMD64/Storage/ATA-PIO.cxx index 3cbba6f7..652aa6f4 100644 --- a/Private/HALKit/AMD64/Storage/ATA-PIO.cxx +++ b/Private/HALKit/AMD64/Storage/ATA-PIO.cxx @@ -58,7 +58,7 @@ Void drv_std_select(UInt16 Bus) { Boolean drv_std_init(UInt16 Bus, UInt8 Drive, UInt16& OutBus, UInt8& OutMaster) { - if (drv_std_detected()) return false; + if (drv_std_detected()) return true; UInt16 IO = Bus; diff --git a/Private/HALKit/POWER/HalStartSequence.s b/Private/HALKit/POWER/HalStartSequence.s index f50a4d4f..fd018304 100644 --- a/Private/HALKit/POWER/HalStartSequence.s +++ b/Private/HALKit/POWER/HalStartSequence.s @@ -4,11 +4,11 @@ ------------------------------------------- */ -.globl Main -.extern HalKernelMain +.globl __ImageStart +.extern hal_init_platform .align 4 .text -Main: - bl HalKernelMain +__ImageStart: + bl hal_init_platform blr diff --git a/Private/Linker/16x0.json b/Private/Linker/16x0.json index 1dd7abbd..5851a2d3 100644 --- a/Private/Linker/16x0.json +++ b/Private/Linker/16x0.json @@ -1,6 +1,6 @@ { "executable_type": "kernel", "output_name": "NewKernel.exe", - "start_proc": "Main", + "start_proc": "__ImageStart", "format": "PEF" } diff --git a/Private/Linker/32x0.json b/Private/Linker/32x0.json index 1dd7abbd..5851a2d3 100644 --- a/Private/Linker/32x0.json +++ b/Private/Linker/32x0.json @@ -1,6 +1,6 @@ { "executable_type": "kernel", "output_name": "NewKernel.exe", - "start_proc": "Main", + "start_proc": "__ImageStart", "format": "PEF" } diff --git a/Private/Linker/64x0.json b/Private/Linker/64x0.json index 1dd7abbd..5851a2d3 100644 --- a/Private/Linker/64x0.json +++ b/Private/Linker/64x0.json @@ -1,6 +1,6 @@ { "executable_type": "kernel", "output_name": "NewKernel.exe", - "start_proc": "Main", + "start_proc": "__ImageStart", "format": "PEF" } diff --git a/Private/NewBoot/BootKit/BootKit.hxx b/Private/NewBoot/BootKit/BootKit.hxx index 15700f54..6272e4c9 100644 --- a/Private/NewBoot/BootKit/BootKit.hxx +++ b/Private/NewBoot/BootKit/BootKit.hxx @@ -6,7 +6,7 @@ /***********************************************************************************/ /// @file Boot.hxx -/// @brief Bootloader API. +/// @brief Bootloader Programming Interface. /***********************************************************************************/ #pragma once @@ -25,7 +25,7 @@ /***********************************************************************************/ #include <NewKit/Defines.hpp> -#include "Builtins/ATA/ATA.hxx" +#include <Builtins/ATA/ATA.hxx> /***********************************************************************************/ /// Framebuffer helpers. @@ -49,6 +49,11 @@ typedef Char *PEImagePtr; typedef WideChar CharacterTypeUTF16; typedef Char CharacterTypeUTF8; +namespace EFI { + extern void ThrowError(const CharacterTypeUTF16 *ErrorCode, + const CharacterTypeUTF16 *Reason) noexcept; +} + /** * @brief BootKit Text Writer class * Writes to UEFI StdOut. @@ -58,7 +63,7 @@ class BTextWriter final { public: BTextWriter &Write(const Long &num); - BTextWriter &Write(const UChar *str); + BTextWriter &Write(const Char *str); BTextWriter &Write(const CharacterTypeUTF16 *str); BTextWriter &WriteCharacter(CharacterTypeUTF16 c); @@ -171,14 +176,19 @@ static inline const UInt32 kRgbBlue = 0x00FF0000; static inline const UInt32 kRgbBlack = 0x00000000; static inline const UInt32 kRgbWhite = 0x00FFFFFF; +#define kBKBootFileMime "boot-x/file" +#define kBKBootDirMime "boot-x/dir" + /// @brief BootKit Disk Formatter. template <typename BootDev> class BDiskFormatFactory final { public: /// @brief File entry for **BDiskFormatFactory**. struct BFileDescriptor final { - Char fFilename[255]; - Char fForkName[255]; + Char fFileName[kNewFSNodeNameLen]; + Char fForkName[kNewFSNodeNameLen]; + + UInt32 fKind; VoidPtr fBlob; SizeT fBlobSz; @@ -190,6 +200,7 @@ public: public: explicit BDiskFormatFactory() = default; explicit BDiskFormatFactory(BootDev dev) : fDiskDev(dev) {} + ~BDiskFormatFactory() = default; NEWOS_COPY_DELETE(BDiskFormatFactory); @@ -204,7 +215,101 @@ public: private: /// @brief Write all of the requested catalogs into the filesystem. - Boolean _AppendCatalogList(BFileDescriptor* fileBlobs, SizeT blobCount) { + Boolean WriteContent(BFileDescriptor* fileBlobs, SizeT blobCount, + SizeT sectorSz, NewPartitionBlock& partBlock) { + if (sectorSz != BootDev::kSectorSize) return false; + + BFileDescriptor* blob = fileBlobs; + Lba startLba = partBlock.FreeCatalog; + + BTextWriter writer; + while (blob) { + NewCatalog catalogKind{ 0 }; + + /// Fill catalog kind. + catalogKind.Kind = blob->fKind; + + /// Allocate fork for blob. + catalogKind.FirstFork = (startLba + sizeof(NewCatalog)); + catalogKind.LastFork = catalogKind.FirstFork; + + NewFork forkKind{ 0 }; + + memcpy(forkKind.Name, blob->fForkName, strlen(blob->fForkName)); + forkKind.Kind = (forkKind.Name[0] == kNewFSDataFork[0]) ? kNewFSDataForkKind : kNewFSRsrcForkKind; + forkKind.Flags = kNewFSFlagCreated; + + /// We don't know. + forkKind.ResourceFlags = 0; + forkKind.ResourceId = 0; + forkKind.ResourceKind = 0; + + /// We're the only fork here. + forkKind.NextSibling = catalogKind.FirstFork; + forkKind.PreviousSibling = catalogKind.FirstFork; + + forkKind.DataOffset = (startLba + sizeof(NewCatalog) + sizeof(NewFork)); + forkKind.DataSize = blob->fBlobSz; + + Lba lbaStart = forkKind.DataOffset; + SizeT cur = 0UL; + + while (cur < forkKind.DataSize) { + this->fDiskDev.Leak().mSize = BootDev::kSectorSize; + this->fDiskDev.Leak().mBase = forkKind.DataOffset / BootDev::kSectorSize; + + this->fDiskDev.Write((Char*)(blob->fBlob) + cur, BootDev::kSectorSize); + + cur += BootDev::kSectorSize; + lbaStart += BootDev::kSectorSize; + } + + writer.Write((catalogKind.Kind == kNewFSCatalogKindFile) ? L"New Boot: Write-File: " : + L"New Boot: Write-Directory: " ).Write(blob->fFileName).Write(L"\r\n"); + + /// Set disk cursor here. + + fDiskDev.Leak().mBase = startLba + sizeof(NewCatalog) / sectorSz; + fDiskDev.Leak().mSize = sizeof(NewFork); + + fDiskDev.Write((Char*)&forkKind, 1); + + /// Fork is done. + + catalogKind.Kind = blob->fKind; + catalogKind.Flags |= kNewFSFlagCreated; + + Lba catalogLba = (sizeof(NewCatalog) - startLba); + + //// Now write catalog as well.. + + catalogKind.PrevSibling = startLba; + catalogKind.NextSibling = (sizeof(NewCatalog) + blob->fBlobSz); + + /// this mime only applies to file. + if (catalogKind.Kind == kNewFSCatalogKindFile) { + memcpy(catalogKind.Mime, kBKBootFileMime, strlen(kBKBootFileMime)); + } else { + memcpy(catalogKind.Mime, kBKBootDirMime, strlen(kBKBootDirMime)); + } + + memcpy(catalogKind.Name, blob->fFileName, strlen(blob->fFileName)); + + fDiskDev.Leak().mBase = startLba / sectorSz; + fDiskDev.Leak().mSize = sizeof(NewCatalog); + + fDiskDev.Write((Char*)&catalogKind, sectorSz); + + startLba += (sizeof(NewCatalog) + blob->fBlobSz); + + --partBlock.FreeCatalog; + --partBlock.FreeSectors; + + ++partBlock.CatalogCount; + + blob = blob->fNext; + } + return true; } @@ -222,28 +327,40 @@ private: template <typename BootDev> inline Boolean BDiskFormatFactory<BootDev>::Format(const char* partName, BDiskFormatFactory::BFileDescriptor* fileBlobs, SizeT blobCount) { - // if (!fileBlobs || !blobCount) return false; + if (!fileBlobs || !blobCount) return false; /// sanity check - static_assert(kNewFSMinimumSectorSz == kATASectorSize, "Sector size doesn't match!"); + /// convert the sector into something that the disk understands. + SizeT sectorSz = BootDev::kSectorSize; + Char buf[BootDev::kSectorSize] = { 0 }; - Char buf[kNewFSMinimumSectorSz] = { 0 }; NewPartitionBlock* partBlock = reinterpret_cast<NewPartitionBlock*>(buf); + memcpy(partBlock->Ident, kNewFSIdent, kNewFSIdentLen-1); memcpy(partBlock->PartitionName, partName, strlen(partName)); /// @note A catalog roughly equal to a sector. - partBlock->CatalogCount = blobCount; + partBlock->CatalogCount = 0UL; partBlock->Kind = kNewFSHardDrive; - partBlock->SectorCount = kNewFSMinimumSectorSz; + partBlock->SectorSize = sectorSz; partBlock->FreeCatalog = fDiskDev.GetSectorsCount() - partBlock->CatalogCount; partBlock->SectorCount = fDiskDev.GetSectorsCount(); partBlock->FreeSectors = fDiskDev.GetSectorsCount() - partBlock->CatalogCount; - partBlock->StartCatalog = kNewFSAddressAsLba + sizeof(NewPartitionBlock); + partBlock->StartCatalog = kNewFSCatalogStartAddress; - fDiskDev.Leak().mBase = (kNewFSAddressAsLba / kNewFSMinimumSectorSz); - fDiskDev.Leak().mSize = kNewFSMinimumSectorSz; - fDiskDev.Write(buf, kNewFSMinimumSectorSz); + if (this->WriteContent(fileBlobs, blobCount, sectorSz, *partBlock)) { + fDiskDev.Leak().mBase = (kNewFSAddressAsLba / sectorSz); + fDiskDev.Leak().mSize = BootDev::kSectorSize; + + fDiskDev.Write(buf, sectorSz); + + BTextWriter writer; + writer.Write(L"New Boot: Write-Partition, OK.\r\n"); + + return true; + } else { + EFI::ThrowError(L"Filesystem-Failure-Part", L"Filesystem couldn't be partitioned."); + } - return this->_AppendCatalogList(fileBlobs, blobCount); + return false; } diff --git a/Private/NewBoot/BootKit/HW/ATA.hxx b/Private/NewBoot/BootKit/HW/ATA.hxx index c557aeb8..4b96e9fa 100644 --- a/Private/NewBoot/BootKit/HW/ATA.hxx +++ b/Private/NewBoot/BootKit/HW/ATA.hxx @@ -23,6 +23,8 @@ class BootDeviceATA final : public Device { NEWOS_COPY_DEFAULT(BootDeviceATA); + enum { kSectorSize = kATASectorSize }; + struct ATATrait final : public Device::Trait { UInt16 mBus{kPrimary}; UInt8 mMaster{0}; diff --git a/Private/NewBoot/Source/HEL/AMD64/BootATA.cxx b/Private/NewBoot/Source/HEL/AMD64/BootATA.cxx index 10d4272d..8d923a50 100644 --- a/Private/NewBoot/Source/HEL/AMD64/BootATA.cxx +++ b/Private/NewBoot/Source/HEL/AMD64/BootATA.cxx @@ -132,7 +132,7 @@ ATAInit_Retry: Void boot_ata_read(UInt64 Lba, UInt16 IO, UInt8 Master, CharacterTypeUTF8* Buf, SizeT SectorSz, SizeT Size) { - UInt8 Command = (!Master ? 0xE0 : 0xF0); + UInt8 Command = ((!Master) ? 0xE0 : 0xF0); boot_ata_wait_io(IO); @@ -146,27 +146,15 @@ Void boot_ata_read(UInt64 Lba, UInt16 IO, UInt8 Master, CharacterTypeUTF8* Buf, Out8(IO + ATA_REG_COMMAND, ATA_CMD_READ_PIO); - while ((In8(ATA_COMMAND(IO))) & ATA_SR_BSY) boot_ata_wait_io(IO); - - UInt16 byte = In16(IO + ATA_REG_DATA); - SizeT IndexOff = 0UL; - Buf[IndexOff] = byte; - - while (byte != 0xFF) { - if (IndexOff > Size) break; - - ++IndexOff; - - while ((In8(ATA_COMMAND(IO))) & ATA_SR_BSY) boot_ata_wait_io(IO); - - byte = In16(IO + ATA_REG_DATA); - Buf[IndexOff] = byte; + for (SizeT IndexOff = 0; IndexOff < Size; ++IndexOff) { + boot_ata_wait_io(IO); + Buf[IndexOff] = In16(IO + ATA_REG_DATA); } } Void boot_ata_write(UInt64 Lba, UInt16 IO, UInt8 Master, CharacterTypeUTF8* Buf, SizeT SectorSz, SizeT Size) { - UInt8 Command = (!Master ? 0xE0 : 0xF0); + UInt8 Command = ((!Master) ? 0xE0 : 0xF0); boot_ata_wait_io(IO); @@ -209,10 +197,6 @@ BootDeviceATA::BootDeviceATA() noexcept { boot_ata_init(ATA_SECONDARY_IO, true, this->Leak().mBus, this->Leak().mMaster)) { kATADetected = true; - - BTextWriter writer; - - writer.Write(L"New Boot: Drive is OnLine.\r\n"); } } /** diff --git a/Private/NewBoot/Source/HEL/AMD64/BootJump.S b/Private/NewBoot/Source/HEL/AMD64/BootJump.S new file mode 100644 index 00000000..af278cc7 --- /dev/null +++ b/Private/NewBoot/Source/HEL/AMD64/BootJump.S @@ -0,0 +1,9 @@ +.global rt_jump_to_address +.text + +.code64 +.intel_syntax noprefix + +rt_jump_to_address: + jmp rcx + ret diff --git a/Private/NewBoot/Source/HEL/AMD64/BootMain.cxx b/Private/NewBoot/Source/HEL/AMD64/BootMain.cxx index 356db88b..ea3fcbf0 100644 --- a/Private/NewBoot/Source/HEL/AMD64/BootMain.cxx +++ b/Private/NewBoot/Source/HEL/AMD64/BootMain.cxx @@ -9,8 +9,15 @@ #include <FirmwareKit/EFI.hxx> #include <KernelKit/MSDOS.hpp> #include <KernelKit/PEF.hpp> -#include <NewKit/Ref.hpp> +#include <NewKit/Macros.hpp> #include <BootKit/BootKit.hxx> +#include <NewKit/Ref.hpp> +#include <cstring> + +/// make the compiler shut up. +#ifndef kMachineModel +#define kMachineModel "NeWS HD" +#endif // !kMachineModel /** Graphics related. */ @@ -18,6 +25,8 @@ STATIC EfiGraphicsOutputProtocol* kGop = nullptr; STATIC UInt16 kStride = 0U; STATIC EfiGUID kGopGuid; +EXTERN_C Void rt_jump_to_address(VoidPtr blob); + /** @brief Finds and stores the GOP. */ @@ -166,45 +175,66 @@ EFI_EXTERN_C EFI_API Int Main(EfiHandlePtr ImageHandle, } } - BFileReader kernelFile(L"NewLoader.exe", ImageHandle); - kernelFile.ReadAll(MIB(1), 4096); + /// + /// The following checks for an exisiting partition + /// inside the disk, if it doesn't have one, + /// format the disk. + // - if (kernelFile.Blob()) { - PEFContainer* containerKind = - reinterpret_cast<PEFContainer*>(kernelFile.Blob()); + /// need this as well, to invoke BExecutableLoader. + BFileReader readerKernel(L"NewKernel.exe", ImageHandle); + readerKernel.ReadAll(MIB(1), 4096); - if (containerKind->Magic[0] == kPefMagic[0] && - containerKind->Magic[1] == kPefMagic[1] && - containerKind->Magic[2] == kPefMagic[2] && - containerKind->Magic[3] == kPefMagic[3] && - containerKind->Magic[4] == kPefMagic[4]) { - if (containerKind->Abi != kPefAbi || - containerKind->Cpu != kPefArchAMD64) { - EFI::ThrowError(L"Bad-Architecture", - L"New Boot can't run this architecture."); - } + BDiskFormatFactory<BootDeviceATA> diskFormatter; - NewOS::HEL::BootMainKind main = - reinterpret_cast<NewOS::HEL::BootMainKind>(containerKind + - containerKind->Start); + BDiskFormatFactory<BootDeviceATA>::BFileDescriptor rootDesc{0}; - if (!main) { - EFI::ThrowError(L"Bad-Exec", - L"New Boot can't recognize this executable."); - } + memcpy(rootDesc.fFileName, "/", strlen("/")); + memcpy(rootDesc.fForkName, kNewFSResourceFork, strlen(kNewFSResourceFork)); - EFI::ExitBootServices(MapKey, ImageHandle); + rootDesc.fBlobSz = strlen(kMachineModel " startup disk."); + rootDesc.fBlob = new Char[rootDesc.fBlobSz]; - main(handoverHdrPtr); + memcpy(rootDesc.fBlob, kMachineModel " startup disk.", + strlen(kMachineModel " startup disk.")); - EFI::Stop(); + rootDesc.fKind = kNewFSCatalogKindDir; - CANT_REACH(); - } - } + BDiskFormatFactory<BootDeviceATA>::BFileDescriptor bootDesc{0}; + + bootDesc.fKind = kNewFSCatalogKindDir; + + memcpy(bootDesc.fFileName, "/Boot", strlen("/Boot")); + memcpy(bootDesc.fForkName, kNewFSResourceFork, strlen(kNewFSResourceFork)); + memcpy(bootDesc.fBlob, kMachineModel " startup folder.", + strlen(kMachineModel " startup folder.")); + + bootDesc.fBlobSz = strlen(kMachineModel " startup folder."); + bootDesc.fBlob = new Char[bootDesc.fBlobSz]; + + BDiskFormatFactory<BootDeviceATA>::BFileDescriptor kernelDesc{0}; + + kernelDesc.fKind = kNewFSCatalogKindFile; + + memcpy(kernelDesc.fFileName, "/Boot/NewKernel", strlen("/Boot/NewKernel")); + memcpy(kernelDesc.fForkName, kNewFSDataFork, strlen(kNewFSDataFork)); + + kernelDesc.fBlob = readerKernel.Blob(); + kernelDesc.fBlobSz = readerKernel.Size(); + + rootDesc.fNext = &bootDesc; + rootDesc.fNext->fPrev = &rootDesc; + + rootDesc.fNext->fNext = &kernelDesc; + rootDesc.fNext->fNext->fPrev = &bootDesc; + + diskFormatter.Format(kMachineModel, &rootDesc, 3); + + EFI::ExitBootServices(MapKey, ImageHandle); + + rt_jump_to_address(readerKernel.Blob()); - EFI::ThrowError(L"Invalid-PEF-Executable", - L"PEF executable expected. Got something else."); + EFI::Stop(); - return kEfiFail; + CANT_REACH(); } diff --git a/Private/NewBoot/Source/HEL/AMD64/BootTextWriter.cxx b/Private/NewBoot/Source/HEL/AMD64/BootTextWriter.cxx index 81aa6c9d..ff30ff95 100644 --- a/Private/NewBoot/Source/HEL/AMD64/BootTextWriter.cxx +++ b/Private/NewBoot/Source/HEL/AMD64/BootTextWriter.cxx @@ -32,7 +32,7 @@ BTextWriter &BTextWriter::Write(const CharacterTypeUTF16 *str) { return *this; } -BTextWriter &BTextWriter::Write(const UChar *str) { +BTextWriter &BTextWriter::Write(const Char *str) { #ifdef __DEBUG__ if (!str || *str == 0) return *this; diff --git a/Private/NewBoot/Source/HEL/AMD64/New+Delete.cxx b/Private/NewBoot/Source/HEL/AMD64/New+Delete.cxx index 77552ef8..01911c43 100644 --- a/Private/NewBoot/Source/HEL/AMD64/New+Delete.cxx +++ b/Private/NewBoot/Source/HEL/AMD64/New+Delete.cxx @@ -20,6 +20,17 @@ void* operator new(size_t sz) return buf; } +/// @brief Allocates a new object. +/// @param sz the size. +/// @return +void* operator new[](size_t sz) +{ + void* buf = nullptr; + BS->AllocatePool(EfiMemoryType::EfiLoaderData, sz, &buf); + + return buf; +} + /// @brief Deletes the object. /// @param buf the object. void operator delete(void* buf) diff --git a/Private/NewBoot/Source/makefile b/Private/NewBoot/Source/makefile index 93bb5e28..92128b02 100644 --- a/Private/NewBoot/Source/makefile +++ b/Private/NewBoot/Source/makefile @@ -18,6 +18,10 @@ else EMU=qemu-system-x86_64 endif +ifeq ($(NEWS_MODEL), ) +NEWOS_MODEL=-DkMachineModel="\"Generic NeWS HD\"" +endif + IMG=epm.img IMG_2=epm-slave.img EMU_FLAGS=-net none -smp 4 -m 8G -M q35 -bios OVMF.fd -device piix3-ide,id=ide -drive id=disk,file=$(IMG),format=raw,if=none -device ide-hd,drive=disk,bus=ide.0 -drive file=fat:rw:CDROM,index=2,format=raw -d int -hdd epm-slave.img @@ -46,13 +50,10 @@ KERNEL=NewKernel.exe .PHONY: all all: compile-amd64 mkdir -p CDROM/EFI/BOOT - $(LD_GNU) $(OBJ) $(LD_FLAGS) -o $(KERNEL_OBJ) - $(IMG_CREATE) create -f raw $(BOOT_LOADER) $(MAX_KERNEL_SIZE) - $(DD) if=$(KERNEL_OBJ) of=$(BOOT_LOADER) bs=1 seek=0 conv=notrunc + $(LD_GNU) $(OBJ) $(LD_FLAGS) -o $(BOOT_LOADER) $(COPY) $(BOOT_LOADER) CDROM/EFI/BOOT/BOOTX64.EFI $(COPY) $(BOOT_LOADER) CDROM/EFI/BOOT/NEWBOOT.EFI $(COPY) ../../$(KERNEL) CDROM/$(KERNEL) - $(COPY) $(BOOT_LOADER) ../../Root/Boot/$(BOOT_LOADER) ifneq ($(DEBUG_SUPPORT), ) DEBUG = -D__DEBUG__ @@ -61,7 +62,7 @@ endif .PHONY: compile-amd64 compile-amd64: $(WINDRES) BootloaderRsrc.rsrc -O coff -o BootloaderRsrc.o - $(CC_GNU) $(FLAG_GNU) $(DEBUG) $(wildcard HEL/AMD64/*.cxx) $(wildcard *.cxx) + $(CC_GNU) $(NEWOS_MODEL) $(FLAG_GNU) $(DEBUG) $(wildcard HEL/AMD64/*.cxx) $(wildcard HEL/AMD64/*.S) $(wildcard *.cxx) .PHONY: run-efi-amd64 run-efi-amd64: @@ -69,7 +70,7 @@ run-efi-amd64: .PHONY: epm-img epm-img: - qemu-img create -f qcow2 $(IMG) 256M + qemu-img create -f qcow2 $(IMG) 512M qemu-img create -f qcow2 $(IMG_2) 512M .PHONY: download-edk diff --git a/Private/NewLoader/ReadMe.md b/Private/NewLoader/ReadMe.md deleted file mode 100644 index 955f0651..00000000 --- a/Private/NewLoader/ReadMe.md +++ /dev/null @@ -1,9 +0,0 @@ -# NewLoader - -## New OS Stage 2 loader. - -Loads and runs the NewKernel and it's components. - -- Loads: NewKernel.exe, a MicroKernel in C++ (PEF) -- Loads: Bonjour.exe, zeroconf driver. (PEF) -- Loads: MahroussUpdate.exe, mahrouss system update driver. (PEF) diff --git a/Private/NewLoader/Source/.gitkeep b/Private/NewLoader/Source/.gitkeep deleted file mode 100644 index e69de29b..00000000 --- a/Private/NewLoader/Source/.gitkeep +++ /dev/null diff --git a/Private/makefile b/Private/makefile index 673a4b56..977e33ac 100644 --- a/Private/makefile +++ b/Private/makefile @@ -5,7 +5,7 @@ CC = x86_64-w64-mingw32-gcc LD = x86_64-w64-mingw32-ld -CCFLAGS = -c -ffreestanding -fPIE -fPIC -D__NEWOS_AMD64__ -mno-red-zone -fno-rtti -fno-exceptions -std=c++20 -D__FSKIT_NEWFS__ -D__KERNEL__ -D__HAVE_MAHROUSS_APIS__ -D__MAHROUSS__ -I../ -I./ +CCFLAGS = -c -ffreestanding -fPIC -D__NEWOS_AMD64__ -mno-red-zone -fno-rtti -fno-exceptions -std=c++20 -D__FSKIT_NEWFS__ -D__KERNEL__ -D__HAVE_MAHROUSS_APIS__ -D__MAHROUSS__ -I../ -I./ ASM = nasm ifneq ($(ATA_PIO_SUPPORT), ) @@ -30,7 +30,7 @@ COPY = cp ASMFLAGS = -f win64 # NewOS subsystem is 17. -LDFLAGS = -e Main --subsystem=17 +LDFLAGS = -e __ImageStart --subsystem=17 LDOBJ = Objects/*.obj # This file is the kernel, responsible of task management and memory. @@ -59,17 +59,13 @@ newos-amd64-epm: clean OBJCOPY=x86_64-w64-mingw32-objcopy -KERNEL_OBJ=kernel.bin DD=dd IMG_CREATE=qemu-img MAX_KERNEL_SIZE=1024K .PHONY: link-amd64-epm link-amd64-epm: - $(LD) $(LDFLAGS) $(LDOBJ) -o $(KERNEL_OBJ) - $(IMG_CREATE) create -f raw $(KERNEL) $(MAX_KERNEL_SIZE) - $(DD) if=$(KERNEL_OBJ) of=$(KERNEL) bs=1 seek=0 conv=notrunc - $(COPY) $(KERNEL) Root/Boot + $(LD) $(LDFLAGS) $(LDOBJ) -o $(KERNEL) .PHONY: all all: newos-amd64-epm link-amd64-epm |
