|
|
|
@ -1,6 +1,6 @@
|
|
|
|
|
# Building
|
|
|
|
|
TARGET := riscv64gc-unknown-none-elf
|
|
|
|
|
MODE := release
|
|
|
|
|
MODE := debug
|
|
|
|
|
KERNEL_ELF := target/$(TARGET)/$(MODE)/os
|
|
|
|
|
KERNEL_BIN := $(KERNEL_ELF).bin
|
|
|
|
|
DISASM_TMP := target/$(TARGET)/$(MODE)/asm
|
|
|
|
@ -11,6 +11,11 @@ SBI ?= rustsbi
|
|
|
|
|
BOOTLOADER := ../bootloader/$(SBI)-$(BOARD).bin
|
|
|
|
|
K210_BOOTLOADER_SIZE := 131072
|
|
|
|
|
|
|
|
|
|
# Building mode argument
|
|
|
|
|
ifeq ($(MODE), release)
|
|
|
|
|
MODE_ARG := --release
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
# KERNEL ENTRY
|
|
|
|
|
ifeq ($(BOARD), qemu)
|
|
|
|
|
KERNEL_ENTRY_PA := 0x80200000
|
|
|
|
@ -51,7 +56,7 @@ kernel:
|
|
|
|
|
@cd ../user && make build
|
|
|
|
|
@echo Platform: $(BOARD)
|
|
|
|
|
@cp src/linker-$(BOARD).ld src/linker.ld
|
|
|
|
|
@cargo build --release
|
|
|
|
|
@cargo build $(MODE_ARG)
|
|
|
|
|
@rm src/linker.ld
|
|
|
|
|
|
|
|
|
|
clean:
|
|
|
|
@ -92,4 +97,10 @@ debug: build
|
|
|
|
|
tmux split-window -h "riscv64-unknown-elf-gdb -ex 'file $(KERNEL_ELF)' -ex 'set arch riscv:rv64' -ex 'target remote localhost:1234'" && \
|
|
|
|
|
tmux -2 attach-session -d
|
|
|
|
|
|
|
|
|
|
.PHONY: build env kernel clean disasm disasm-vim run-inner switch-check
|
|
|
|
|
gdbserver: build
|
|
|
|
|
@qemu-system-riscv64 -machine virt -nographic -bios $(BOOTLOADER) -device loader,file=$(KERNEL_BIN),addr=$(KERNEL_ENTRY_PA) -s -S
|
|
|
|
|
|
|
|
|
|
gdbclient:
|
|
|
|
|
@riscv64-unknown-elf-gdb -ex 'file $(KERNEL_ELF)' -ex 'set arch riscv:rv64' -ex 'target remote localhost:1234'
|
|
|
|
|
|
|
|
|
|
.PHONY: build env kernel clean disasm disasm-vim run-inner switch-check gdbserver
|
|
|
|
|