Makefile.src 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. HOST ?= $(shell uname -s | tr '[:upper:]' '[:lower:]')
  2. ARCH ?= ##DEFAULT_ARCH##
  3. MODE ?= debug
  4. SMP ?= 4
  5. QEMU ?= ##QEMU##
  6. GDB ?= ##GDB##
  7. FDISK ?= ##FDISK##
  8. COMMA := ,
  9. PROFILE = $(MODE)
  10. ifeq ($(MODE),debug)
  11. PROFILE := dev
  12. endif
  13. USER_PROGRAMS = $(shell find user-programs -type f)
  14. KERNEL_SOURCES := $(shell find src macros crates -name '*.rs' -type f)
  15. KERNEL_CARGO_MANIFESTS += $(shell find src macros crates -name Cargo.toml -type f)
  16. KERNEL_DEPS := $(KERNEL_SOURCES) $(KERNEL_CARGO_MANIFESTS)
  17. QEMU_ARGS ?= -no-reboot -no-shutdown
  18. CARGO_FLAGS := --profile $(PROFILE) --features $(FEATURES)$(if $(SMP),$(COMMA)smp,)
  19. ifeq ($(HOST),darwin)
  20. QEMU_ACCEL ?= -accel tcg
  21. else ifeq ($(HOST),linux)
  22. QEMU_ACCEL ?= -accel kvm
  23. endif
  24. QEMU_ARGS += $(QEMU_ACCEL)
  25. ifneq ($(DEBUG_TRAPS),)
  26. QEMU_ARGS += -d cpu_reset,int,guest_errors -D build/qemu.log
  27. endif
  28. ifneq ($(SMP),)
  29. QEMU_ARGS += -smp $(SMP)
  30. endif
  31. ifeq ($(ARCH),riscv64)
  32. BINARY_DIR_BASE := build/riscv64gc-unknown-none-elf
  33. BINARY_DIR := $(BINARY_DIR_BASE)/$(MODE)
  34. QEMU_ARGS += \
  35. -machine virt -kernel $(BINARY_DIR)/eonix_kernel \
  36. -device virtio-blk-device,drive=disk0,bus=virtio-mmio-bus.0 \
  37. -device virtio-blk-device,drive=disk1,bus=virtio-mmio-bus.1 \
  38. -device virtio-net-device,netdev=mynet0 \
  39. -drive id=disk0,file=build/boot-riscv64.img,format=raw,if=none \
  40. -drive id=disk1,file=test/sdcard-rv.img,format=raw,if=none \
  41. -netdev user,id=mynet0 \
  42. -rtc base=utc
  43. CARGO_FLAGS += --target riscv64gc-unknown-none-elf
  44. .PHONY: build
  45. build: $(BINARY_DIR)/eonix_kernel build/boot-riscv64.img
  46. else ifeq ($(ARCH),x86_64)
  47. BINARY_DIR_BASE := build/x86_64-unknown-none
  48. BINARY_DIR := $(BINARY_DIR_BASE)/$(MODE)
  49. QEMU_ARGS += \
  50. -machine q35 \
  51. -device ahci,id=ahci -device ide-hd,drive=disk,bus=ahci.0 \
  52. -device ide-hd,drive=disk1,bus=ahci.1 \
  53. -device e1000e,netdev=mynet0 \
  54. -drive id=disk,file=build/boot-x86_64.img,format=raw,if=none \
  55. -drive id=disk1,file=test/sdcard-rv.img,format=raw,if=none \
  56. -netdev user,id=mynet0
  57. CARGO_FLAGS += --target x86_64-unknown-none.json
  58. .PHONY: build
  59. build: $(BINARY_DIR)/eonix_kernel build/boot-x86_64.img
  60. endif
  61. .PHONY: run
  62. run: build build/kernel.sym
  63. $(QEMU) $(QEMU_ARGS) -display none -serial mon:stdio
  64. .PHONY: srun
  65. srun: build build/kernel.sym
  66. $(QEMU) $(QEMU_ARGS) -display none -S -s -serial mon:stdio
  67. .PHONY: clean
  68. clean:
  69. -rm -rf build
  70. -mkdir build
  71. .PHONY: clean-all
  72. clean-all: clean
  73. -rm Makefile
  74. .PHONY: debug
  75. debug: build/kernel.sym
  76. -RUST_GDB=$(GDB) rust-gdb --symbols=build/kernel.sym \
  77. -iex 'source pretty-print.py' \
  78. -iex 'set pagination off' \
  79. -iex 'set output-radix 16' \
  80. -iex 'set print asm-demangle on' \
  81. -iex 'set print pretty on' \
  82. -iex 'target remote:1234'
  83. -killall $(QEMU)
  84. .PHONY: tmux-debug
  85. tmux-debug:
  86. tmux new-session -s gbos-debug -d
  87. -tmux split-window -t gbos-debug -hf
  88. -tmux send-keys -t gbos-debug:1.1 'make srun' C-m
  89. -tmux send-keys -t gbos-debug:1.2 'make debug' C-m C-m
  90. -tmux attach -t gbos-debug
  91. tmux kill-session -t gbos-debug
  92. $(BINARY_DIR)/eonix_kernel: $(KERNEL_DEPS)
  93. cargo build $(CARGO_FLAGS)
  94. build/kernel.sym: $(BINARY_DIR)/eonix_kernel
  95. cargo objcopy -q $(CARGO_FLAGS) -- --only-keep-debug build/kernel.sym
  96. build/mbr.bin: $(BINARY_DIR)/eonix_kernel
  97. cargo objcopy -q $(CARGO_FLAGS) -- -O binary -j .mbr build/mbr.bin
  98. build/stage1.bin: $(BINARY_DIR)/eonix_kernel
  99. cargo objcopy -q $(CARGO_FLAGS) -- -O binary -j .stage1 build/stage1.bin
  100. build/kernel.bin: $(BINARY_DIR)/eonix_kernel
  101. cargo objcopy -q $(CARGO_FLAGS) -- -O binary --strip-debug \
  102. -R .mbr -R .stage1 build/kernel.bin
  103. build/boot-x86_64.img: build/fs-x86_64.img build/mbr.bin build/stage1.bin build/kernel.bin
  104. dd if=build/mbr.bin of=$@ bs=512 count=1 conv=notrunc 2> /dev/null
  105. dd if=build/stage1.bin of=$@ bs=512 seek=1 conv=notrunc 2> /dev/null
  106. dd if=build/kernel.bin of=$@ bs=4096 seek=1 conv=notrunc 2> /dev/null
  107. dd if=$< of=$@ bs=$(shell expr 4 \* 1024 \* 1024) \
  108. seek=1 conv=notrunc 2> /dev/null
  109. sh -c 'echo n; echo; echo; echo 8192; echo; echo a; echo w' \
  110. | $(FDISK) $@ 2> /dev/null > /dev/null
  111. build/boot-riscv64.img: build/fs-riscv64.img
  112. dd if=$< of=$@ bs=$(shell expr 4 \* 1024 \* 1024) \
  113. seek=1 conv=notrunc 2> /dev/null
  114. sh -c 'echo n; echo; echo; echo 8192; echo; echo a; echo w' \
  115. | $(FDISK) $@ 2> /dev/null > /dev/null
  116. .DEFAULT_GOAL := build