mirror of
https://github.com/Zeal-Operating-System/ZealOS.git
synced 2025-01-13 08:06:31 +00:00
zealbooter: Rebase on latest limine-barebones code
This commit is contained in:
parent
c97456cfb2
commit
9477ad40fc
3 changed files with 56 additions and 43 deletions
10
.gitignore
vendored
10
.gitignore
vendored
|
@ -2,17 +2,17 @@
|
||||||
*.bin
|
*.bin
|
||||||
*.ZXE
|
*.ZXE
|
||||||
*.MAP
|
*.MAP
|
||||||
src/Boot/
|
/src/Boot
|
||||||
*.ELF
|
*.ELF
|
||||||
*.elf
|
*.elf
|
||||||
*.sys
|
*.sys
|
||||||
*.SYS
|
*.SYS
|
||||||
src/EFI/
|
/src/EFI
|
||||||
build/limine
|
/build/limine
|
||||||
build/ovmf
|
/build/ovmf
|
||||||
*.iso
|
*.iso
|
||||||
*.raw
|
*.raw
|
||||||
*.hdd
|
*.hdd
|
||||||
*.o
|
*.o
|
||||||
*.d
|
*.d
|
||||||
zealbooter/limine.h
|
/zealbooter/limine.h
|
||||||
|
|
|
@ -1,8 +1,11 @@
|
||||||
|
# Nuke built-in rules and variables.
|
||||||
|
override MAKEFLAGS += -rR
|
||||||
|
|
||||||
# This is the name that our final kernel executable will have.
|
# This is the name that our final kernel executable will have.
|
||||||
# Change as needed.
|
# Change as needed.
|
||||||
override KERNEL := zealbooter.elf
|
override KERNEL := zealbooter.elf
|
||||||
|
|
||||||
# Convenience macro to reliably declare overridable command variables.
|
# Convenience macro to reliably declare user overridable variables.
|
||||||
define DEFAULT_VAR =
|
define DEFAULT_VAR =
|
||||||
ifeq ($(origin $1),default)
|
ifeq ($(origin $1),default)
|
||||||
override $(1) := $(2)
|
override $(1) := $(2)
|
||||||
|
@ -20,49 +23,54 @@ $(eval $(call DEFAULT_VAR,CC,cc))
|
||||||
# Same thing for "ld" (the linker).
|
# Same thing for "ld" (the linker).
|
||||||
$(eval $(call DEFAULT_VAR,LD,ld))
|
$(eval $(call DEFAULT_VAR,LD,ld))
|
||||||
|
|
||||||
# User controllable CFLAGS.
|
# User controllable C flags.
|
||||||
CFLAGS ?= -g -O2 -pipe -Wall -Wextra
|
$(eval $(call DEFAULT_VAR,CFLAGS,-g -O2 -pipe -Wall -Wextra))
|
||||||
|
|
||||||
# User controllable preprocessor flags. We set none by default.
|
# User controllable C preprocessor flags. We set none by default.
|
||||||
CPPFLAGS ?=
|
$(eval $(call DEFAULT_VAR,CPPFLAGS,))
|
||||||
|
|
||||||
# User controllable nasm flags.
|
# User controllable nasm flags.
|
||||||
NASMFLAGS ?= -F dwarf -g
|
$(eval $(call DEFAULT_VAR,NASMFLAGS,-F dwarf -g))
|
||||||
|
|
||||||
# User controllable linker flags. We set none by default.
|
# User controllable linker flags. We set none by default.
|
||||||
LDFLAGS ?=
|
$(eval $(call DEFAULT_VAR,LDFLAGS,))
|
||||||
|
|
||||||
# Internal C flags that should not be changed by the user.
|
# Internal C flags that should not be changed by the user.
|
||||||
override CFLAGS += \
|
override CFLAGS += \
|
||||||
-std=gnu11 \
|
-std=gnu11 \
|
||||||
-ffreestanding \
|
-ffreestanding \
|
||||||
-fno-stack-protector \
|
-fno-stack-protector \
|
||||||
-fno-stack-check \
|
-fno-stack-check \
|
||||||
-fno-lto \
|
-fno-lto \
|
||||||
-fno-pie \
|
-fno-pie \
|
||||||
-fno-pic \
|
-fno-pic \
|
||||||
-m64 \
|
-m64 \
|
||||||
-march=x86-64 \
|
-march=x86-64 \
|
||||||
-mabi=sysv \
|
-mabi=sysv \
|
||||||
-mno-80387 \
|
-mno-80387 \
|
||||||
-mno-mmx \
|
-mno-mmx \
|
||||||
-mno-sse \
|
-mno-sse \
|
||||||
-mno-sse2 \
|
-mno-sse2 \
|
||||||
-mno-red-zone \
|
-mno-red-zone \
|
||||||
-mcmodel=kernel \
|
-mcmodel=kernel
|
||||||
-MMD \
|
|
||||||
-I. \
|
# Internal C preprocessor flags that should not be changed by the user.
|
||||||
-I./lib
|
override CPPFLAGS := \
|
||||||
|
-I. \
|
||||||
|
-I./lib \
|
||||||
|
$(CPPFLAGS) \
|
||||||
|
-MMD \
|
||||||
|
-MP
|
||||||
|
|
||||||
# Internal linker flags that should not be changed by the user.
|
# Internal linker flags that should not be changed by the user.
|
||||||
override LDFLAGS += \
|
override LDFLAGS += \
|
||||||
-nostdlib \
|
-nostdlib \
|
||||||
-static \
|
-static \
|
||||||
-m elf_x86_64 \
|
-m elf_x86_64 \
|
||||||
-z max-page-size=0x1000 \
|
-z max-page-size=0x1000 \
|
||||||
-T linker.ld
|
-T linker.ld
|
||||||
|
|
||||||
# Check if the linker supports -no-pie and enable it if it does
|
# Check if the linker supports -no-pie and enable it if it does.
|
||||||
ifeq ($(shell $(LD) --help 2>&1 | grep 'no-pie' >/dev/null 2>&1; echo $$?),0)
|
ifeq ($(shell $(LD) --help 2>&1 | grep 'no-pie' >/dev/null 2>&1; echo $$?),0)
|
||||||
override LDFLAGS += -no-pie
|
override LDFLAGS += -no-pie
|
||||||
endif
|
endif
|
||||||
|
@ -71,10 +79,11 @@ endif
|
||||||
override NASMFLAGS += \
|
override NASMFLAGS += \
|
||||||
-f elf64
|
-f elf64
|
||||||
|
|
||||||
# Use find to glob all *.c, *.S, and *.asm files in the directory and extract the object names.
|
# Use "find" to glob all *.c, *.S, and *.asm files in the tree and obtain the
|
||||||
override CFILES := $(shell find . -type f -name '*.c')
|
# object and header dependency file names.
|
||||||
override ASFILES := $(shell find . -type f -name '*.S')
|
override CFILES := $(shell find -L . -type f -name '*.c')
|
||||||
override NASMFILES := $(shell find . -type f -name '*.asm')
|
override ASFILES := $(shell find -L . -type f -name '*.S')
|
||||||
|
override NASMFILES := $(shell find -L . -type f -name '*.asm')
|
||||||
override OBJ := $(CFILES:.c=.o) $(ASFILES:.S=.o) $(NASMFILES:.asm=.o)
|
override OBJ := $(CFILES:.c=.o) $(ASFILES:.S=.o) $(NASMFILES:.asm=.o)
|
||||||
override HEADER_DEPS := $(CFILES:.c=.d) $(ASFILES:.S=.d)
|
override HEADER_DEPS := $(CFILES:.c=.d) $(ASFILES:.S=.d)
|
||||||
|
|
||||||
|
@ -83,7 +92,7 @@ override HEADER_DEPS := $(CFILES:.c=.d) $(ASFILES:.S=.d)
|
||||||
all: $(KERNEL)
|
all: $(KERNEL)
|
||||||
|
|
||||||
limine.h:
|
limine.h:
|
||||||
curl https://raw.githubusercontent.com/limine-bootloader/limine/trunk/limine.h -o $@ || cp ../build/limine/limine.h limine.h || echo "ERROR"
|
curl -Lo $@ https://github.com/limine-bootloader/limine/raw/trunk/limine.h || cp ../build/limine/limine.h limine.h || echo "ERROR"
|
||||||
|
|
||||||
# Link rules for the final kernel executable.
|
# Link rules for the final kernel executable.
|
||||||
$(KERNEL): $(OBJ)
|
$(KERNEL): $(OBJ)
|
||||||
|
@ -94,11 +103,11 @@ $(KERNEL): $(OBJ)
|
||||||
|
|
||||||
# Compilation rules for *.c files.
|
# Compilation rules for *.c files.
|
||||||
%.o: %.c limine.h
|
%.o: %.c limine.h
|
||||||
$(CC) $(CPPFLAGS) $(CFLAGS) -c $< -o $@
|
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
|
||||||
|
|
||||||
# Compilation rules for *.S files.
|
# Compilation rules for *.S files.
|
||||||
%.o: %.S limine.h
|
%.o: %.S limine.h
|
||||||
$(CC) $(CPPFLAGS) $(CFLAGS) -c $< -o $@
|
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
|
||||||
|
|
||||||
# Compilation rules for *.asm (nasm) files.
|
# Compilation rules for *.asm (nasm) files.
|
||||||
%.o: %.asm
|
%.o: %.asm
|
||||||
|
|
|
@ -40,6 +40,10 @@ SECTIONS
|
||||||
*(.data .data.*)
|
*(.data .data.*)
|
||||||
} :data
|
} :data
|
||||||
|
|
||||||
|
/* NOTE: .bss needs to be the last thing mapped to :data, otherwise lots of */
|
||||||
|
/* unnecessary zeros will be written to the binary. */
|
||||||
|
/* If you need, for example, .init_array and .fini_array, those should be placed */
|
||||||
|
/* above this. */
|
||||||
.bss : {
|
.bss : {
|
||||||
*(COMMON)
|
*(COMMON)
|
||||||
*(.bss .bss.*)
|
*(.bss .bss.*)
|
||||||
|
|
Loading…
Reference in a new issue