Makefile 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. # 导入环境变量
  2. include env.mk
  3. export ROOT_PATH=$(shell pwd)
  4. SUBDIRS = kernel user tools build-scripts
  5. # todo: 增加参数,判断是否在QEMU中仿真,若是,则启用该环境变量
  6. # export EMULATOR=__QEMU_EMULATION__
  7. # 计算cpu核心数
  8. NPROCS:=1
  9. OS:=$(shell uname -s)
  10. ifeq ($(OS),Linux)
  11. NPROCS:=$(shell grep -c ^processor /proc/cpuinfo)
  12. endif
  13. ifeq ($(OS),Darwin) # Assume Mac OS X
  14. NPROCS:=$(shell system_profiler | awk '/Number Of CPUs/{print $4}{next;}')
  15. endif
  16. # 检查是否需要进行fmt --check
  17. # 解析命令行参数
  18. FMT_CHECK?=0
  19. ifeq ($(FMT_CHECK), 1)
  20. FMT_CHECK=--check
  21. else
  22. FMT_CHECK=
  23. endif
  24. .PHONY: all
  25. all: kernel user
  26. .PHONY: kernel
  27. kernel:
  28. mkdir -p bin/kernel/
  29. $(MAKE) -C ./kernel all ARCH=$(ARCH) || (sh -c "echo 内核编译失败" && exit 1)
  30. .PHONY: user
  31. user:
  32. $(MAKE) -C ./user all ARCH=$(ARCH) || (sh -c "echo 用户程序编译失败" && exit 1)
  33. .PHONY: clean
  34. clean:
  35. @list='$(SUBDIRS)'; for subdir in $$list; do \
  36. echo "Clean in dir: $$subdir";\
  37. cd $$subdir && $(MAKE) clean;\
  38. cd .. ;\
  39. done
  40. .PHONY: ECHO
  41. ECHO:
  42. @echo "$@"
  43. cppcheck-xml:
  44. cppcheck kernel user --platform=unix64 --std=c11 -I user/libs/ -I=kernel/ --force -j $(NPROCS) --xml 2> cppcheck.xml
  45. cppcheck:
  46. cppcheck kernel user --platform=unix64 --std=c11 -I user/libs/ -I=kernel/ --force -j $(NPROCS)
  47. docs: ECHO
  48. bash -c "cd docs && make html && cd .."
  49. clean-docs:
  50. bash -c "cd docs && make clean && cd .."
  51. gdb:
  52. ifeq ($(ARCH), x86_64)
  53. rust-gdb -n -x tools/.gdbinit
  54. else
  55. gdb-multiarch -n -x tools/.gdbinit
  56. endif
  57. # 写入磁盘镜像
  58. write_diskimage:
  59. @echo "write_diskimage arch=$(ARCH)"
  60. bash -c "export ARCH=$(ARCH); cd tools && bash grub_auto_install.sh && sudo ARCH=$(ARCH) bash $(ROOT_PATH)/tools/write_disk_image.sh --bios=legacy && cd .."
  61. # 写入磁盘镜像(uefi)
  62. write_diskimage-uefi:
  63. bash -c "export ARCH=$(ARCH); cd tools && bash grub_auto_install.sh && sudo ARCH=$(ARCH) bash $(ROOT_PATH)/tools/write_disk_image.sh --bios=uefi && cd .."
  64. # 不编译,直接启动QEMU
  65. qemu:
  66. sh -c "cd tools && bash run-qemu.sh --bios=legacy --display=window && cd .."
  67. # 不编译,直接启动QEMU(UEFI)
  68. qemu-uefi:
  69. sh -c "cd tools && bash run-qemu.sh --bios=uefi --display=window && cd .."
  70. # 不编译,直接启动QEMU,使用VNC Display作为图像输出
  71. qemu-vnc:
  72. sh -c "cd tools && bash run-qemu.sh --bios=legacy --display=vnc && cd .."
  73. # 不编译,直接启动QEMU(UEFI),使用VNC Display作为图像输出
  74. qemu-uefi-vnc:
  75. sh -c "cd tools && bash run-qemu.sh --bios=uefi --display=vnc && cd .."
  76. # 编译并写入磁盘镜像
  77. build:
  78. $(MAKE) all -j $(NPROCS)
  79. $(MAKE) write_diskimage || exit 1
  80. # 在docker中编译,并写入磁盘镜像
  81. docker:
  82. @echo "使用docker构建"
  83. sudo bash tools/build_in_docker.sh || exit 1
  84. $(MAKE) write_diskimage || exit 1
  85. # uefi方式启动
  86. run-uefi:
  87. $(MAKE) all -j $(NPROCS)
  88. $(MAKE) write_diskimage-uefi || exit 1
  89. $(MAKE) qemu-uefi
  90. # 编译并启动QEMU
  91. run:
  92. $(MAKE) all -j $(NPROCS)
  93. $(MAKE) write_diskimage || exit 1
  94. $(MAKE) qemu
  95. # uefi方式启动,使用VNC Display作为图像输出
  96. run-uefi-vnc:
  97. $(MAKE) all -j $(NPROCS)
  98. $(MAKE) write_diskimage-uefi || exit 1
  99. $(MAKE) qemu-uefi-vnc
  100. # 编译并启动QEMU,使用VNC Display作为图像输出
  101. run-vnc:
  102. $(MAKE) all -j $(NPROCS)
  103. $(MAKE) write_diskimage || exit 1
  104. $(MAKE) qemu-vnc
  105. # 在docker中编译,并启动QEMU
  106. run-docker:
  107. @echo "使用docker构建并运行"
  108. sudo bash tools/build_in_docker.sh || exit 1
  109. $(MAKE) write_diskimage || exit 1
  110. $(MAKE) qemu
  111. fmt:
  112. @echo "格式化代码"
  113. FMT_CHECK=$(FMT_CHECK) $(MAKE) fmt -C kernel
  114. FMT_CHECK=$(FMT_CHECK) $(MAKE) fmt -C user
  115. FMT_CHECK=$(FMT_CHECK) $(MAKE) fmt -C build-scripts
  116. log-monitor:
  117. @echo "启动日志监控"
  118. @sh -c "cd tools/debugging/logmonitor && cargo run --release -- --log-dir $(ROOT_PATH)/logs/ --kernel $(ROOT_PATH)/bin/kernel/kernel.elf"
  119. .PHONY: update-submodules
  120. update-submodules:
  121. @echo "更新子模块"
  122. @git submodule update --recursive
  123. @git submodule foreach git pull origin master
  124. .PHONY: update-submodules-by-mirror
  125. update-submodules-by-mirror:
  126. @echo "从镜像更新子模块"
  127. @git config --global url."https://git.mirrors.dragonos.org.cn/DragonOS-Community/".insteadOf https://github.com/DragonOS-Community/
  128. @$(MAKE) update-submodules
  129. @git config --global --unset url."https://git.mirrors.dragonos.org.cn/DragonOS-Community/".insteadOf
  130. help:
  131. @echo "编译:"
  132. @echo " make all -j <n> - 本地编译,不运行,n为要用于编译的CPU核心数"
  133. @echo " make build - 本地编译,并写入磁盘镜像"
  134. @echo " make docker - Docker编译,并写入磁盘镜像"
  135. @echo ""
  136. @echo "编译并运行:"
  137. @echo " make run-docker - Docker编译,写入磁盘镜像,并在QEMU中运行"
  138. @echo " make run - 本地编译,写入磁盘镜像,并在QEMU中运行"
  139. @echo " make run-uefi - 以uefi方式启动运行"
  140. @echo ""
  141. @echo "运行:"
  142. @echo " make qemu - 不编译,直接从已有的磁盘镜像启动运行"
  143. @echo " make qemu-uefi - 不编译,直接从已有的磁盘镜像以UEFI启动运行"
  144. @echo ""
  145. @echo ""
  146. @echo "注: 对于上述的run, run-uefi, qemu, qemu-uefi命令可以在命令后加上-vnc后缀,来通过vnc连接到DragonOS, 默认会在5900端口运行vnc服务器。如:make run-vnc "
  147. @echo ""
  148. @echo "其他:"
  149. @echo " make clean - 清理编译产生的文件"
  150. @echo " make fmt - 格式化代码"
  151. @echo " make log-monitor - 启动日志监控"
  152. @echo " make docs - 生成文档"
  153. @echo " make clean-docs - 清理文档"
  154. @echo ""
  155. @echo " make update-submodules - 更新子模块"
  156. @echo " make update-submodules-by-mirror - 从镜像更新子模块"