This repository has been archived on 2022-12-02. You can view files and clone it, but cannot push or open issues or pull requests.
2021-07-26 12:50:37 +00:00
|
|
|
TARGET = riscv64-unknown-elf
|
|
|
|
CC = $(TARGET)-gcc
|
|
|
|
GDB = $(TARGET)-gdb
|
|
|
|
EMU = qemu-system-riscv64
|
2021-07-25 19:09:53 +00:00
|
|
|
|
2021-07-26 12:50:37 +00:00
|
|
|
CODE = src/
|
|
|
|
|
|
|
|
CFLAGS = -march=rv64gc -mabi=lp64d -static -mcmodel=medany -fvisibility=hidden -nostdlib -nostartfiles -Tkernel.ld -g -Wall -Wextra
|
|
|
|
ifeq ($(CC),clang)
|
|
|
|
CFLAGS += -target $(TARGET) -mno-relax -Wno-unused-command-line-argument
|
|
|
|
endif
|
|
|
|
|
|
|
|
EFLAGS = -machine virt -cpu rv64 -bios opensbi-riscv64-generic-fw_dynamic.bin -m 256m -nographic -global virtio-mmio.force-legacy=false -s
|
|
|
|
ifdef WAIT_GDB
|
|
|
|
EFLAGS += -S
|
|
|
|
endif
|
|
|
|
|
|
|
|
.PHONY: all clean run gdb
|
2021-07-25 19:09:53 +00:00
|
|
|
|
|
|
|
all: $(CODE)*.s $(CODE)*.c
|
|
|
|
$(CC) $(CFLAGS) $? -o kernel
|
2021-07-26 12:50:37 +00:00
|
|
|
|
|
|
|
clean:
|
|
|
|
-rm kernel
|
|
|
|
|
2021-07-25 19:09:53 +00:00
|
|
|
run:
|
|
|
|
$(EMU) $(EFLAGS) -kernel kernel
|
2021-07-25 20:26:52 +00:00
|
|
|
|
|
|
|
gdb:
|
2021-08-19 21:05:45 +00:00
|
|
|
$(GDB) -q -x kernel.gdb
|