rules.mk 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. OBJ_DIR := $(OBJ_DIR)/$(TARGET)
  2. # Include source folder paths to virtual paths
  3. C_SOURCES := $(abspath ${C_SOURCES})
  4. ASM_SOURCES := $(abspath ${ASM_SOURCES})
  5. CPP_SOURCES := $(abspath ${CPP_SOURCES})
  6. # Gather object
  7. OBJECTS = $(addprefix $(OBJ_DIR)/, $(C_SOURCES:.c=.o))
  8. OBJECTS += $(addprefix $(OBJ_DIR)/, $(ASM_SOURCES:.s=.o))
  9. OBJECTS += $(addprefix $(OBJ_DIR)/, $(CPP_SOURCES:.cpp=.o))
  10. OBJECT_DIRS = $(sort $(dir $(OBJECTS)))
  11. # Generate dependencies
  12. DEPS = $(OBJECTS:.o=.d)
  13. ifdef DFU_SERIAL
  14. DFU_OPTIONS += -S $(DFU_SERIAL)
  15. endif
  16. $(foreach dir, $(OBJECT_DIRS),$(shell mkdir -p $(dir)))
  17. BUILD_FLAGS_SHELL=\
  18. echo "$(CFLAGS)" > $(OBJ_DIR)/BUILD_FLAGS.tmp; \
  19. diff -u $(OBJ_DIR)/BUILD_FLAGS $(OBJ_DIR)/BUILD_FLAGS.tmp 2>&1 > /dev/null \
  20. && ( echo "CFLAGS ok"; rm $(OBJ_DIR)/BUILD_FLAGS.tmp) \
  21. || ( echo "CFLAGS has been changed"; mv $(OBJ_DIR)/BUILD_FLAGS.tmp $(OBJ_DIR)/BUILD_FLAGS )
  22. $(info $(shell $(BUILD_FLAGS_SHELL)))
  23. CHECK_AND_REINIT_SUBMODULES_SHELL=\
  24. if git submodule status | egrep -q '^[-]|^[+]' ; then \
  25. echo "INFO: Need to reinitialize git submodules"; \
  26. git submodule sync; \
  27. git submodule update --init; \
  28. fi
  29. $(info $(shell $(CHECK_AND_REINIT_SUBMODULES_SHELL)))
  30. all: $(OBJ_DIR)/$(PROJECT).elf $(OBJ_DIR)/$(PROJECT).hex $(OBJ_DIR)/$(PROJECT).bin $(OBJ_DIR)/$(PROJECT).dfu $(OBJ_DIR)/$(PROJECT).json
  31. @:
  32. $(OBJ_DIR)/$(PROJECT).elf: $(OBJECTS)
  33. @echo "\tLD\t" $@
  34. @$(LD) $(LDFLAGS) $(OBJECTS) -o $@
  35. @$(SZ) $@
  36. $(OBJ_DIR)/$(PROJECT).hex: $(OBJ_DIR)/$(PROJECT).elf
  37. @echo "\tHEX\t" $@
  38. @$(HEX) $< $@
  39. $(OBJ_DIR)/$(PROJECT).bin: $(OBJ_DIR)/$(PROJECT).elf
  40. @echo "\tBIN\t" $@
  41. @$(BIN) $< $@
  42. $(OBJ_DIR)/$(PROJECT).dfu: $(OBJ_DIR)/$(PROJECT).bin
  43. @echo "\tDFU\t" $@
  44. @../scripts/bin2dfu.py \
  45. -i $(OBJ_DIR)/$(PROJECT).bin \
  46. -o $(OBJ_DIR)/$(PROJECT).dfu \
  47. -a $(FLASH_ADDRESS) \
  48. -l "Flipper Zero $(shell echo $(TARGET) | tr a-z A-Z)" > /dev/null
  49. $(OBJ_DIR)/$(PROJECT).json: $(OBJ_DIR)/$(PROJECT).dfu
  50. @echo "\tJSON\t" $@
  51. @$(PROJECT_ROOT)/scripts/meta.py generate -p $(PROJECT) $(CFLAGS) > $(OBJ_DIR)/$(PROJECT).json
  52. $(OBJ_DIR)/%.o: %.c $(OBJ_DIR)/BUILD_FLAGS
  53. @echo "\tCC\t" $(subst $(PROJECT_ROOT)/, , $<)
  54. @$(CC) $(CFLAGS) -c $< -o $@
  55. $(OBJ_DIR)/%.o: %.s $(OBJ_DIR)/BUILD_FLAGS
  56. @echo "\tASM\t" $(subst $(PROJECT_ROOT)/, , $<)
  57. @$(AS) $(CFLAGS) -c $< -o $@
  58. $(OBJ_DIR)/%.o: %.cpp $(OBJ_DIR)/BUILD_FLAGS
  59. @echo "\tCPP\t" $(subst $(PROJECT_ROOT)/, , $<)
  60. @$(CPP) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
  61. $(OBJ_DIR)/flash: $(OBJ_DIR)/$(PROJECT).bin
  62. openocd $(OPENOCD_OPTS) -c "program $(OBJ_DIR)/$(PROJECT).bin reset exit $(FLASH_ADDRESS)"
  63. touch $@
  64. $(OBJ_DIR)/upload: $(OBJ_DIR)/$(PROJECT).bin
  65. dfu-util -d 0483:df11 -D $(OBJ_DIR)/$(PROJECT).bin -a 0 -s $(FLASH_ADDRESS) $(DFU_OPTIONS)
  66. touch $@
  67. .PHONY: flash
  68. flash: $(OBJ_DIR)/flash
  69. .PHONY: upload
  70. upload: $(OBJ_DIR)/upload
  71. .PHONY: debug
  72. debug: flash
  73. arm-none-eabi-gdb-py \
  74. -ex 'target extended-remote | openocd -c "gdb_port pipe" $(OPENOCD_OPTS)' \
  75. -ex "set confirm off" \
  76. -ex "source ../debug/FreeRTOS/FreeRTOS.py" \
  77. -ex "source ../debug/PyCortexMDebug/PyCortexMDebug.py" \
  78. -ex "svd_load $(SVD_FILE)" \
  79. -ex "compare-sections" \
  80. $(OBJ_DIR)/$(PROJECT).elf; \
  81. .PHONY: debug_other
  82. debug_other:
  83. arm-none-eabi-gdb-py \
  84. -ex 'target extended-remote | openocd -c "gdb_port pipe" $(OPENOCD_OPTS)' \
  85. -ex "set confirm off" \
  86. -ex "source ../debug/PyCortexMDebug/PyCortexMDebug.py" \
  87. -ex "svd_load $(SVD_FILE)" \
  88. .PHONY: blackmagic
  89. blackmagic:
  90. arm-none-eabi-gdb-py \
  91. -ex 'target extended-remote $(BLACKMAGIC)' \
  92. -ex 'monitor swdp_scan' \
  93. -ex 'monitor debug_bmp enable' \
  94. -ex 'attach 1' \
  95. -ex 'set confirm off' \
  96. -ex 'set mem inaccessible-by-default off' \
  97. -ex "source ../debug/FreeRTOS/FreeRTOS.py" \
  98. -ex "source ../debug/PyCortexMDebug/PyCortexMDebug.py" \
  99. -ex "svd_load $(SVD_FILE)" \
  100. -ex "compare-sections" \
  101. $(OBJ_DIR)/$(PROJECT).elf; \
  102. .PHONY: openocd
  103. openocd:
  104. openocd $(OPENOCD_OPTS)
  105. .PHONY: clean
  106. clean:
  107. @echo "\tCLEAN\t"
  108. @$(RM) -rf $(OBJ_DIR)
  109. .PHONY: z
  110. z: clean
  111. $(MAKE) all
  112. .PHONY: zz
  113. zz: clean
  114. $(MAKE) flash
  115. .PHONY: zzz
  116. zzz: clean
  117. $(MAKE) debug
  118. .PHONY: generate_cscope_db
  119. generate_cscope_db:
  120. @echo "$(C_SOURCES) $(CPP_SOURCES) $(ASM_SOURCES)" | tr ' ' '\n' > $(OBJ_DIR)/source.list.p
  121. @cat ~/headers.list >> $(OBJ_DIR)/source.list.p
  122. @cat $(OBJ_DIR)/source.list.p | sed -e "s|^[^//]|$$PWD/&|g" > $(OBJ_DIR)/source.list
  123. @cscope -b -k -i $(OBJ_DIR)/source.list -f $(OBJ_DIR)/cscope.out
  124. @rm -rf $(OBJ_DIR)/source.list $(OBJ_DIR)/source.list.p
  125. # Prevent make from searching targets for real files
  126. %.d: ;
  127. %.c: ;
  128. %.cpp: ;
  129. %.s: ;
  130. $(OBJ_DIR)/BUILD_FLAGS: ;
  131. -include $(DEPS)