Makefile 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  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. .PHONY: all
  31. all: kernel user
  32. .PHONY: kernel
  33. kernel:
  34. mkdir -p bin/kernel/
  35. @if [ -z $$DragonOS_GCC ]; then echo "\033[31m [错误]尚未安装DragonOS交叉编译器, 请使用tools文件夹下的build_gcc_toolchain.sh脚本安装 \033[0m"; exit 1; fi
  36. $(MAKE) -C ./kernel all || (sh -c "echo 内核编译失败" && exit 1)
  37. .PHONY: user
  38. user:
  39. @if [ -z $$DragonOS_GCC ]; then echo "\033[31m [错误]尚未安装DragonOS交叉编译器, 请使用tools文件夹下的build_gcc_toolchain.sh脚本安装 \033[0m"; exit 1; fi
  40. $(MAKE) -C ./user all || (sh -c "echo 用户程序编译失败" && exit 1)
  41. .PHONY: clean
  42. clean:
  43. @list='$(SUBDIRS)'; for subdir in $$list; do \
  44. echo "Clean in dir: $$subdir";\
  45. cd $$subdir && $(MAKE) clean;\
  46. cd .. ;\
  47. done
  48. .PHONY: ECHO
  49. ECHO:
  50. @echo "$@"
  51. cppcheck-xml:
  52. cppcheck kernel user --platform=unix64 --std=c11 -I user/libs/ -I=kernel/ --force -j $(NPROCS) --xml 2> cppcheck.xml
  53. cppcheck:
  54. cppcheck kernel user --platform=unix64 --std=c11 -I user/libs/ -I=kernel/ --force -j $(NPROCS)
  55. docs: ECHO
  56. bash -c "cd docs && make html && cd .."
  57. clean-docs:
  58. bash -c "cd docs && make clean && cd .."
  59. gdb:
  60. rust-gdb -n -x tools/.gdbinit
  61. # 写入磁盘镜像
  62. write_diskimage:
  63. bash -c "cd tools && bash grub_auto_install.sh && sudo bash $(ROOT_PATH)/tools/write_disk_image.sh --bios=legacy && cd .."
  64. # 写入磁盘镜像(uefi)
  65. write_diskimage-uefi:
  66. bash -c "cd tools && bash grub_auto_install.sh && sudo bash $(ROOT_PATH)/tools/write_disk_image.sh --bios=uefi && cd .."
  67. # 不编译,直接启动QEMU
  68. qemu:
  69. sh -c "cd tools && bash run-qemu.sh --bios=legacy --display=window && cd .."
  70. # 不编译,直接启动QEMU(UEFI)
  71. qemu-uefi:
  72. sh -c "cd tools && bash run-qemu.sh --bios=uefi --display=window && cd .."
  73. # 不编译,直接启动QEMU,使用VNC Display作为图像输出
  74. qemu-vnc:
  75. sh -c "cd tools && bash run-qemu.sh --bios=legacy --display=vnc && cd .."
  76. # 不编译,直接启动QEMU(UEFI),使用VNC Display作为图像输出
  77. qemu-uefi-vnc:
  78. sh -c "cd tools && bash run-qemu.sh --bios=uefi --display=vnc && cd .."
  79. # 编译并写入磁盘镜像
  80. build:
  81. $(MAKE) all -j $(NPROCS)
  82. $(MAKE) write_diskimage || exit 1
  83. # 在docker中编译,并写入磁盘镜像
  84. docker:
  85. @echo "使用docker构建"
  86. sudo bash tools/build_in_docker.sh || exit 1
  87. $(MAKE) write_diskimage || exit 1
  88. # uefi方式启动
  89. run-uefi:
  90. $(MAKE) all -j $(NPROCS)
  91. $(MAKE) write_diskimage-uefi || exit 1
  92. $(MAKE) qemu-uefi
  93. # 编译并启动QEMU
  94. run:
  95. $(MAKE) all -j $(NPROCS)
  96. $(MAKE) write_diskimage || exit 1
  97. $(MAKE) qemu
  98. # uefi方式启动,使用VNC Display作为图像输出
  99. run-uefi-vnc:
  100. $(MAKE) all -j $(NPROCS)
  101. $(MAKE) write_diskimage-uefi || exit 1
  102. $(MAKE) qemu-uefi-vnc
  103. # 编译并启动QEMU,使用VNC Display作为图像输出
  104. run-vnc:
  105. $(MAKE) all -j $(NPROCS)
  106. $(MAKE) write_diskimage || exit 1
  107. $(MAKE) qemu-vnc
  108. # 在docker中编译,并启动QEMU
  109. run-docker:
  110. @echo "使用docker构建并运行"
  111. sudo bash tools/build_in_docker.sh || exit 1
  112. $(MAKE) write_diskimage || exit 1
  113. $(MAKE) qemu
  114. help:
  115. @echo "编译:"
  116. @echo " make all -j <n> - 本地编译,不运行,n为要用于编译的CPU核心数"
  117. @echo " make build - 本地编译,并写入磁盘镜像"
  118. @echo " make docker - Docker编译,并写入磁盘镜像"
  119. @echo ""
  120. @echo "编译并运行:"
  121. @echo " make run-docker - Docker编译,写入磁盘镜像,并在QEMU中运行"
  122. @echo " make run - 本地编译,写入磁盘镜像,并在QEMU中运行"
  123. @echo " make run-uefi - 以uefi方式启动运行"
  124. @echo ""
  125. @echo "运行:"
  126. @echo " make qemu - 不编译,直接从已有的磁盘镜像启动运行"
  127. @echo " make qemu-uefi - 不编译,直接从已有的磁盘镜像以UEFI启动运行"
  128. @echo ""
  129. @echo ""
  130. @echo "注: 对于上述的run, run-uefi, qemu, qemu-uefi命令可以在命令后加上-vnc后缀,来通过vnc连接到DragonOS, 默认会在5900端口运行vnc服务器。如:make run-vnc "