summaryrefslogtreecommitdiffhomepage
path: root/Private/makefile
diff options
context:
space:
mode:
authorAmlal <amlalelmahrouss@icloud.com>2024-04-26 12:29:13 +0000
committerAmlal <amlalelmahrouss@icloud.com>2024-04-26 12:29:13 +0000
commit97eb8462433a831f8a02a08acfc7ca32e794d37d (patch)
treee7cddb857e50a2cca41a5364b4240cd8c6c0ec13 /Private/makefile
parentf7a7080d18ac2be758b242c22f020c018b1c4824 (diff)
parent313c303fab092b1c45e615f960826375e7eef093 (diff)
Merged in MHR-16 (pull request #6)
MHR-16 - A lot of features and USA design.
Diffstat (limited to 'Private/makefile')
-rw-r--r--Private/makefile15
1 files changed, 7 insertions, 8 deletions
diff --git a/Private/makefile b/Private/makefile
index 41f70c81..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), )
@@ -28,10 +28,12 @@ COPY = cp
# Add assembler, linker, and object files variables.
ASMFLAGS = -f win64
-LDFLAGS = -e Main --subsystem=17
+
+# NewOS subsystem is 17.
+LDFLAGS = -e __ImageStart --subsystem=17
LDOBJ = Objects/*.obj
-# This file is the kernel, responsible of task management, memory, drivers and more.
+# This file is the kernel, responsible of task management and memory.
KERNEL = NewKernel.exe
# The kernel entrypoint
@@ -39,6 +41,7 @@ SCRIPT = --script=Linker/Platforms/PC.lds
.PHONY: error
error:
+ @echo "=== ERROR ==="
@echo "=> Use a specific target."
MOVEALL=./MoveAll.sh
@@ -56,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