Makefile 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  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 RUSTC=$(shell which rustc)
  20. export DEBUG=DEBUG
  21. export GLOBAL_CFLAGS := -mcmodel=large -fno-builtin -m64 -fno-stack-protector -D $(ARCH) -D $(EMULATOR) -O1
  22. ifeq ($(DEBUG), DEBUG)
  23. GLOBAL_CFLAGS += -g
  24. endif
  25. export CC=gcc
  26. .PHONY: all
  27. all: kernel user
  28. .PHONY: kernel
  29. kernel:
  30. mkdir -p bin/kernel/
  31. $(MAKE) -C ./kernel all || (sh -c "echo 内核编译失败" && exit 1)
  32. .PHONY: user
  33. user:
  34. mkdir -p bin/user/
  35. mkdir -p bin/tmp/user
  36. $(MAKE) -C ./user all || (sh -c "echo 用户程序编译失败" && exit 1)
  37. .PHONY: clean
  38. clean:
  39. @list='$(SUBDIRS)'; for subdir in $$list; do \
  40. echo "Clean in dir: $$subdir";\
  41. cd $$subdir && $(MAKE) clean;\
  42. cd .. ;\
  43. done
  44. cppcheck-xml:
  45. cppcheck kernel user --platform=unix64 --std=c11 -I user/libs/ -I=kernel/ --force -j $(NPROCS) --xml 2> cppcheck.xml
  46. cppcheck:
  47. cppcheck kernel user --platform=unix64 --std=c11 -I user/libs/ -I=kernel/ --force -j $(NPROCS)
  48. gdb:
  49. gdb -n -x tools/.gdbinit
  50. # 写入磁盘镜像
  51. write_diskimage:
  52. sudo sh -c "cd tools && bash $(ROOT_PATH)/tools/write_disk_image.sh --bios=legacy && cd .."
  53. # 写入磁盘镜像(uefi)
  54. write_diskimage-uefi:
  55. sudo sh -c "cd tools && bash $(ROOT_PATH)/tools/write_disk_image.sh --bios=uefi && cd .."
  56. # 不编译,直接启动QEMU
  57. qemu:
  58. sh -c "cd tools && bash run-qemu.sh --bios=legacy && cd .."
  59. # 不编译,直接启动QEMU(UEFI)
  60. qemu-uefi:
  61. sh -c "cd tools && bash run-qemu.sh --bios=uefi && cd .."
  62. # 编译并写入磁盘镜像
  63. build:
  64. $(MAKE) all -j $(NPROCS)
  65. $(MAKE) write_diskimage || exit 1
  66. # 在docker中编译,并写入磁盘镜像
  67. docker:
  68. @echo "使用docker构建"
  69. sudo bash tools/build_in_docker.sh || exit 1
  70. # uefi方式启动
  71. run-uefi:
  72. $(MAKE) all -j $(NPROCS)
  73. $(MAKE) write_diskimage-uefi || exit 1
  74. $(MAKE) qemu-uefi
  75. # 编译并启动QEMU
  76. run:
  77. $(MAKE) all -j $(NPROCS)
  78. $(MAKE) write_diskimage || exit 1
  79. $(MAKE) qemu
  80. # 在docker中编译,并启动QEMU
  81. run-docker:
  82. @echo "使用docker构建并运行"
  83. sudo bash tools/build_in_docker.sh || exit 1
  84. $(MAKE) qemu