Makefile 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. SUBDIRS = kernel user
  2. # ifndef $(EMULATOR)
  3. ifeq ($(EMULATOR), )
  4. export EMULATOR=__NO_EMULATION__
  5. endif
  6. # todo: 增加参数,判断是否在QEMU中仿真,若是,则启用该环境变量
  7. # export EMULATOR=__QEMU_EMULATION__
  8. # 计算cpu核心数
  9. NPROCS:=1
  10. OS:=$(shell uname -s)
  11. ifeq ($(OS),Linux)
  12. NPROCS:=$(shell grep -c ^processor /proc/cpuinfo)
  13. endif
  14. ifeq ($(OS),Darwin) # Assume Mac OS X
  15. NPROCS:=$(shell system_profiler | awk '/Number Of CPUs/{print $4}{next;}')
  16. endif
  17. export ARCH=__x86_64__
  18. export ROOT_PATH=$(shell pwd)
  19. export DEBUG=DEBUG
  20. export GLOBAL_CFLAGS := -mcmodel=large -fno-builtin -m64 -fno-stack-protector -D $(ARCH) -D $(EMULATOR) -O1
  21. ifeq ($(DEBUG), DEBUG)
  22. GLOBAL_CFLAGS += -g
  23. endif
  24. export CC=$(DragonOS_GCC)/x86_64-elf-gcc
  25. export LD=ld
  26. export AS=$(DragonOS_GCC)/x86_64-elf-as
  27. export NM=$(DragonOS_GCC)/x86_64-elf-nm
  28. export AR=$(DragonOS_GCC)/x86_64-elf-ar
  29. export OBJCOPY=$(DragonOS_GCC)/x86_64-elf-objcopy
  30. # 检查是否需要进行fmt --check
  31. # 解析命令行参数
  32. FMT_CHECK?=0
  33. ifeq ($(FMT_CHECK), 1)
  34. FMT_CHECK=--check
  35. else
  36. FMT_CHECK=
  37. endif
  38. .PHONY: all
  39. all: kernel user
  40. .PHONY: kernel
  41. kernel:
  42. mkdir -p bin/kernel/
  43. @if [ -z $$DragonOS_GCC ]; then echo "\033[31m [错误]尚未安装DragonOS交叉编译器, 请使用tools文件夹下的build_gcc_toolchain.sh脚本安装 \033[0m"; exit 1; fi
  44. $(MAKE) -C ./kernel all || (sh -c "echo 内核编译失败" && exit 1)
  45. .PHONY: user
  46. user:
  47. @if [ -z $$DragonOS_GCC ]; then echo "\033[31m [错误]尚未安装DragonOS交叉编译器, 请使用tools文件夹下的build_gcc_toolchain.sh脚本安装 \033[0m"; exit 1; fi
  48. $(MAKE) -C ./user all || (sh -c "echo 用户程序编译失败" && exit 1)
  49. .PHONY: clean
  50. clean:
  51. @list='$(SUBDIRS)'; for subdir in $$list; do \
  52. echo "Clean in dir: $$subdir";\
  53. cd $$subdir && $(MAKE) clean;\
  54. cd .. ;\
  55. done
  56. .PHONY: ECHO
  57. ECHO:
  58. @echo "$@"
  59. cppcheck-xml:
  60. cppcheck kernel user --platform=unix64 --std=c11 -I user/libs/ -I=kernel/ --force -j $(NPROCS) --xml 2> cppcheck.xml
  61. cppcheck:
  62. cppcheck kernel user --platform=unix64 --std=c11 -I user/libs/ -I=kernel/ --force -j $(NPROCS)
  63. docs: ECHO
  64. bash -c "cd docs && make html && cd .."
  65. clean-docs:
  66. bash -c "cd docs && make clean && cd .."
  67. gdb:
  68. rust-gdb -n -x tools/.gdbinit
  69. # 写入磁盘镜像
  70. write_diskimage:
  71. bash -c "cd tools && bash grub_auto_install.sh && sudo bash $(ROOT_PATH)/tools/write_disk_image.sh --bios=legacy && cd .."
  72. # 写入磁盘镜像(uefi)
  73. write_diskimage-uefi:
  74. bash -c "cd tools && bash grub_auto_install.sh && sudo bash $(ROOT_PATH)/tools/write_disk_image.sh --bios=uefi && cd .."
  75. # 不编译,直接启动QEMU
  76. qemu:
  77. sh -c "cd tools && bash run-qemu.sh --bios=legacy --display=window && cd .."
  78. # 不编译,直接启动QEMU(UEFI)
  79. qemu-uefi:
  80. sh -c "cd tools && bash run-qemu.sh --bios=uefi --display=window && cd .."
  81. # 不编译,直接启动QEMU,使用VNC Display作为图像输出
  82. qemu-vnc:
  83. sh -c "cd tools && bash run-qemu.sh --bios=legacy --display=vnc && cd .."
  84. # 不编译,直接启动QEMU(UEFI),使用VNC Display作为图像输出
  85. qemu-uefi-vnc:
  86. sh -c "cd tools && bash run-qemu.sh --bios=uefi --display=vnc && cd .."
  87. # 编译并写入磁盘镜像
  88. build:
  89. $(MAKE) all -j $(NPROCS)
  90. $(MAKE) write_diskimage || exit 1
  91. # 在docker中编译,并写入磁盘镜像
  92. docker:
  93. @echo "使用docker构建"
  94. sudo bash tools/build_in_docker.sh || exit 1
  95. $(MAKE) write_diskimage || exit 1
  96. # uefi方式启动
  97. run-uefi:
  98. $(MAKE) all -j $(NPROCS)
  99. $(MAKE) write_diskimage-uefi || exit 1
  100. $(MAKE) qemu-uefi
  101. # 编译并启动QEMU
  102. run:
  103. $(MAKE) all -j $(NPROCS)
  104. $(MAKE) write_diskimage || exit 1
  105. $(MAKE) qemu
  106. # uefi方式启动,使用VNC Display作为图像输出
  107. run-uefi-vnc:
  108. $(MAKE) all -j $(NPROCS)
  109. $(MAKE) write_diskimage-uefi || exit 1
  110. $(MAKE) qemu-uefi-vnc
  111. # 编译并启动QEMU,使用VNC Display作为图像输出
  112. run-vnc:
  113. $(MAKE) all -j $(NPROCS)
  114. $(MAKE) write_diskimage || exit 1
  115. $(MAKE) qemu-vnc
  116. # 在docker中编译,并启动QEMU
  117. run-docker:
  118. @echo "使用docker构建并运行"
  119. sudo bash tools/build_in_docker.sh || exit 1
  120. $(MAKE) write_diskimage || exit 1
  121. $(MAKE) qemu
  122. fmt:
  123. @echo "格式化代码"
  124. FMT_CHECK=$(FMT_CHECK) $(MAKE) fmt -C kernel
  125. FMT_CHECK=$(FMT_CHECK) $(MAKE) fmt -C user
  126. help:
  127. @echo "编译:"
  128. @echo " make all -j <n> - 本地编译,不运行,n为要用于编译的CPU核心数"
  129. @echo " make build - 本地编译,并写入磁盘镜像"
  130. @echo " make docker - Docker编译,并写入磁盘镜像"
  131. @echo ""
  132. @echo "编译并运行:"
  133. @echo " make run-docker - Docker编译,写入磁盘镜像,并在QEMU中运行"
  134. @echo " make run - 本地编译,写入磁盘镜像,并在QEMU中运行"
  135. @echo " make run-uefi - 以uefi方式启动运行"
  136. @echo ""
  137. @echo "运行:"
  138. @echo " make qemu - 不编译,直接从已有的磁盘镜像启动运行"
  139. @echo " make qemu-uefi - 不编译,直接从已有的磁盘镜像以UEFI启动运行"
  140. @echo ""
  141. @echo ""
  142. @echo "注: 对于上述的run, run-uefi, qemu, qemu-uefi命令可以在命令后加上-vnc后缀,来通过vnc连接到DragonOS, 默认会在5900端口运行vnc服务器。如:make run-vnc "