|
@@ -2,7 +2,6 @@ arch ?= riscv64
|
|
|
target := $(arch)imac-unknown-none-elf
|
|
|
mode := release
|
|
|
kernel := target/$(target)/$(mode)/riscv
|
|
|
-bin := target/$(target)/$(mode)/kernel.bin
|
|
|
img := target/$(target)/$(mode)/img
|
|
|
|
|
|
sysroot := $(shell rustc --print sysroot)
|
|
@@ -14,12 +13,6 @@ ifeq ($(mode), release)
|
|
|
BUILD_ARGS += --release
|
|
|
endif
|
|
|
|
|
|
-ifeq ($(arch), riscv32)
|
|
|
- START_ADDR := 0x80400000
|
|
|
-else ifeq ($(arch), riscv64)
|
|
|
- START_ADDR := 0x80200000
|
|
|
-endif
|
|
|
-
|
|
|
.PHONY: kernel build clean qemu run env
|
|
|
|
|
|
build: $(bin)
|
|
@@ -31,9 +24,6 @@ env:
|
|
|
kernel:
|
|
|
cargo build $(BUILD_ARGS)
|
|
|
|
|
|
-$(bin): kernel
|
|
|
- $(objcopy) $(kernel) --strip-all -O binary $@
|
|
|
-
|
|
|
asm:
|
|
|
$(objdump) -d $(kernel) | less
|
|
|
|
|
@@ -46,18 +36,18 @@ header:
|
|
|
clean:
|
|
|
cargo clean
|
|
|
|
|
|
-qemu: $(bin) $(img)
|
|
|
- sudo qemu-system-$(arch) \
|
|
|
+qemu: kernel $(img)
|
|
|
+ qemu-system-$(arch) \
|
|
|
-machine virt \
|
|
|
-serial mon:stdio \
|
|
|
-bios default \
|
|
|
- -device loader,file=$(bin),addr=$(START_ADDR) \
|
|
|
+ -kernel $(kernel) \
|
|
|
-drive file=$(img),if=none,format=raw,id=x0 \
|
|
|
-device virtio-blk-device,drive=x0 \
|
|
|
-device virtio-gpu-device \
|
|
|
-device virtio-mouse-device \
|
|
|
- -netdev type=tap,id=net0,script=no,downscript=no \
|
|
|
- -device virtio-net-device,netdev=net0
|
|
|
+ # -netdev type=tap,id=net0,script=no,downscript=no \
|
|
|
+ # -device virtio-net-device,netdev=net0
|
|
|
|
|
|
$(img):
|
|
|
dd if=/dev/zero of=$@ bs=512 count=32
|