Makefile.src 4.4 KB

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