summaryrefslogtreecommitdiff
path: root/Makefile
blob: d3f0121a770397367a07c7546f4c3b7e2d5a4c13 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
TOOLCHAIN     := $(HOME)/bin/arm-gnu-toolchain-14.2.rel1-x86_64-aarch64-none-elf
TOOLCHAIN_BIN := $(TOOLCHAIN)/bin
TOOLCHAIN_LIB := $(TOOLCHAIN)/lib/gcc/aarch64-none-elf/14.2.1/include

AS      := $(TOOLCHAIN_BIN)/aarch64-none-elf-as
CC      := $(TOOLCHAIN_BIN)/aarch64-none-elf-gcc
LD      := $(TOOLCHAIN_BIN)/aarch64-none-elf-ld
OBJCOPY := $(TOOLCHAIN_BIN)/aarch64-none-elf-objcopy

SRC_DIR   := src
BUILD_DIR := build
OBJ_DIR   := $(BUILD_DIR)
BIN_DIR   := $(BUILD_DIR)/bin

IMG := $(BIN_DIR)/kernel8.img
ELF := $(BIN_DIR)/kernel8.elf

SRC     := $(wildcard $(SRC_DIR)/*.c)
OBJ     := $(SRC:$(SRC_DIR)/%.c=$(OBJ_DIR)/%.o)
DEP     := $(SRC:$(SRC_DIR)/%.c=$(OBJ_DIR)/%.d)
ASM_SRC := $(wildcard $(SRC_DIR)/*.s)
ASM_OBJ := $(ASM_SRC:$(SRC_DIR)/%.s=$(OBJ_DIR)/%.o)
LINK    := $(SRC_DIR)/link.ld

CPPFLAGS := -MMD -MP -I$(TOOLCHAIN_LIB) -I$(SRC_DIR)
CFLAGS   := -Wall -Wextra -O2 -ffreestanding -nostdinc -nostdlib -nostartfiles
LDFLAGS  := -nostdlib

.PHONY: all clean

all: $(IMG)

$(IMG): $(ELF) | $(BIN_DIR)
	@echo Building $@
	$(OBJCOPY) -O binary $(ELF) $@

$(ELF): $(OBJ) $(ASM_OBJ) | $(BIN_DIR)
	@echo Building $@
	$(LD) $(LDFLAGS) $^ -T $(LINK) -o $@

$(OBJ_DIR)/%.o: $(SRC_DIR)/%.c | $(BUILD_DIR)
	@echo Building $< "->" $@
	$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@

$(OBJ_DIR)/%.o: $(SRC_DIR)/%.s | $(BUILD_DIR)
	@echo Building $< "->" $@
	$(AS) $< -o $@

clean:
	rm -rf $(BUILD_DIR)

$(BUILD_DIR):
	mkdir -p $(BUILD_DIR)
	
$(BIN_DIR):
	mkdir -p $(BIN_DIR)

-include $(DEP)