-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
67 lines (48 loc) · 1.8 KB
/
Makefile
File metadata and controls
67 lines (48 loc) · 1.8 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
60
61
62
63
64
65
66
67
# Makefile for riscv-minios
CC = riscv64-linux-gnu-gcc
LD = riscv64-linux-gnu-ld
OBJCOPY = riscv64-linux-gnu-objcopy
CFLAGS = -Wall -Werror -O2 -fno-common -fno-builtin -nostdlib -mcmodel=medany -I./include
LDFLAGS = -T kernel/kernel.ld -nostdlib
# 编译 usys.S(作为用户代码,但链接到内核)
user/usys.o: user/usys.S
$(CC) $(CFLAGS) -c $< -o $@
OBJS = kernel/entry.o kernel/main.o kernel/uart.o kernel/printf.o kernel/console.o \
kernel/mm/pmm.o kernel/mm/vm.o \
kernel/trap/trap.o kernel/trap/trapvec.o \
kernel/proc/proc.o kernel/proc/swtch.o \
kernel/syscall.o user/usys.o \
kernel/string.o
kernel/string.o: kernel/string.c
$(CC) $(CFLAGS) -c $< -o $@
kernel.elf: $(OBJS)
$(LD) $(LDFLAGS) -o $@ $(OBJS)
kernel/entry.o: kernel/entry.S
$(CC) $(CFLAGS) -c $< -o $@
kernel/main.o: kernel/main.c
$(CC) $(CFLAGS) -c $< -o $@
kernel/uart.o: kernel/uart.c
$(CC) $(CFLAGS) -c $< -o $@
kernel/printf.o: kernel/printf.c
$(CC) $(CFLAGS) -c $< -o $@
kernel/console.o: kernel/console.c
$(CC) $(CFLAGS) -c $< -o $@
kernel/trap/trap.o: kernel/trap/trap.c
$(CC) $(CFLAGS) -c $< -o $@
kernel/trap/trapvec.o: kernel/trap/trapvec.S
$(CC) $(CFLAGS) -c $< -o $@
kernel/proc/proc.o: kernel/proc/proc.c
$(CC) $(CFLAGS) -c $< -o $@
kernel/proc/swtch.o: kernel/proc/swtch.S
$(CC) $(CFLAGS) -c $< -o $@
run: kernel.elf
qemu-system-riscv64 -machine virt -bios none -kernel kernel.elf -nographic -serial mon:stdio
debug: kernel.elf
qemu-system-riscv64 -machine virt -bios none -kernel kernel.elf -nographic -serial mon:stdio -S -gdb tcp::1234
dump-dtb:
qemu-system-riscv64 -machine virt,dumpdtb=virt.dtb -nographic
dtc -I dtb -O dts virt.dtb > virt.dts
@grep -A5 -B5 -E "uart|memory" virt.dts
clean:
rm -f kernel.elf $(OBJS) virt.dtb virt.dts
.PHONY: run debug dump-dtb clean