-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
59 lines (43 loc) · 1.36 KB
/
Makefile
File metadata and controls
59 lines (43 loc) · 1.36 KB
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
CROSS = riscv64-unknown-elf-
CC = $(CROSS)gcc
LD = $(CROSS)ld
OBJCOPY = $(CROSS)objcopy
OBJDUMP = $(CROSS)objdump
CFLAGS = -march=rv64gc -mabi=lp64 -mcmodel=medany -ffreestanding -nostdlib -nostartfiles \
-Wall -Wextra -O2 -Iinclude -g
LDFLAGS = -T linker.ld -nostdlib -Wl,-Map=build/kernel.map
# Source files
SRC_C = kernel/kmain.c kernel/trap.c kernel/task.c kernel/sched.c kernel/shell.c kernel/sync.c kernel/kmem.c \
drivers/uart.c drivers/timer.c \
lib/printf.c
SRC_S = boot/start.S
# Object files
OBJ_C = $(patsubst %.c,build/%.o,$(SRC_C))
OBJ_S = $(patsubst %.S,build/%.o,$(SRC_S))
OBJ = $(OBJ_C) $(OBJ_S)
# Targets
.PHONY: all run run-gdb gdb smoke clean dtb
all: build/kernel.elf
build/kernel.elf: $(OBJ) linker.ld
$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(OBJ)
$(OBJDUMP) -D $@ > build/kernel.asm
build/%.o: %.c
@mkdir -p $(dir $@)
$(CC) $(CFLAGS) -c $< -o $@
build/%.o: %.S
@mkdir -p $(dir $@)
$(CC) $(CFLAGS) -c $< -o $@
run: build/kernel.elf
@bash scripts/run-qemu.sh
run-gdb: build/kernel.elf
@bash scripts/run-qemu.sh gdb
gdb: build/kernel.elf
$(CROSS)gdb build/kernel.elf -ex "target remote :1234"
smoke: build/kernel.elf
@bash scripts/smoke.sh
clean:
rm -rf build/
dtb:
qemu-system-riscv64 -machine virt,dumpdtb=virt.dtb -nographic -bios default
dtc -I dtb -O dts virt.dtb -o virt.dts
@echo "DTB dumped to virt.dtb and virt.dts"