186 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
OBJ_DIR := $(OBJ_DIR)/$(TARGET)-$(PROJECT)
 | 
						|
 | 
						|
# Include source folder paths to virtual paths
 | 
						|
C_SOURCES := $(abspath ${C_SOURCES})
 | 
						|
ASM_SOURCES := $(abspath ${ASM_SOURCES})
 | 
						|
CPP_SOURCES := $(abspath ${CPP_SOURCES})
 | 
						|
 | 
						|
# Gather object
 | 
						|
OBJECTS = $(addprefix $(OBJ_DIR)/, $(C_SOURCES:.c=.o))
 | 
						|
OBJECTS += $(addprefix $(OBJ_DIR)/, $(ASM_SOURCES:.s=.o))
 | 
						|
OBJECTS += $(addprefix $(OBJ_DIR)/, $(CPP_SOURCES:.cpp=.o))
 | 
						|
 | 
						|
OBJECT_DIRS = $(sort $(dir $(OBJECTS)))
 | 
						|
 | 
						|
# Generate dependencies
 | 
						|
DEPS = $(OBJECTS:.o=.d)
 | 
						|
 | 
						|
ifdef DFU_SERIAL
 | 
						|
	DFU_OPTIONS += -S $(DFU_SERIAL)
 | 
						|
endif
 | 
						|
 | 
						|
$(foreach dir, $(OBJECT_DIRS),$(shell mkdir -p $(dir)))
 | 
						|
 | 
						|
BUILD_FLAGS_SHELL=\
 | 
						|
	echo $(OBJ_DIR) ;\
 | 
						|
	echo "$(CFLAGS)" > $(OBJ_DIR)/BUILD_FLAGS.tmp; \
 | 
						|
	diff -u $(OBJ_DIR)/BUILD_FLAGS $(OBJ_DIR)/BUILD_FLAGS.tmp 2>&1 > /dev/null \
 | 
						|
		&& ( echo "CFLAGS ok"; rm $(OBJ_DIR)/BUILD_FLAGS.tmp) \
 | 
						|
		|| ( echo "CFLAGS has been changed"; mv $(OBJ_DIR)/BUILD_FLAGS.tmp $(OBJ_DIR)/BUILD_FLAGS )
 | 
						|
$(info $(shell $(BUILD_FLAGS_SHELL)))
 | 
						|
 | 
						|
CHECK_AND_REINIT_SUBMODULES_SHELL=\
 | 
						|
	if git submodule status | egrep -q '^[-]|^[+]' ; then \
 | 
						|
		echo "INFO: Need to reinitialize git submodules"; \
 | 
						|
		git submodule sync; \
 | 
						|
		git submodule update --init; \
 | 
						|
	fi
 | 
						|
$(info $(shell $(CHECK_AND_REINIT_SUBMODULES_SHELL)))
 | 
						|
 | 
						|
 | 
						|
all: $(OBJ_DIR)/$(PROJECT).elf $(OBJ_DIR)/$(PROJECT).hex $(OBJ_DIR)/$(PROJECT).bin $(OBJ_DIR)/$(PROJECT).dfu $(OBJ_DIR)/$(PROJECT).json
 | 
						|
	@:
 | 
						|
 | 
						|
$(OBJ_DIR)/$(PROJECT).elf: $(OBJECTS)
 | 
						|
	@echo "\tLD\t" $@
 | 
						|
	@$(LD) $(LDFLAGS) $(OBJECTS) -o $@
 | 
						|
	@$(SZ) $@
 | 
						|
 | 
						|
$(OBJ_DIR)/$(PROJECT).hex: $(OBJ_DIR)/$(PROJECT).elf
 | 
						|
	@echo "\tHEX\t" $@
 | 
						|
	@$(HEX) $< $@
 | 
						|
 | 
						|
$(OBJ_DIR)/$(PROJECT).bin: $(OBJ_DIR)/$(PROJECT).elf
 | 
						|
	@echo "\tBIN\t" $@
 | 
						|
	@$(BIN) $< $@
 | 
						|
 | 
						|
$(OBJ_DIR)/$(PROJECT).dfu: $(OBJ_DIR)/$(PROJECT).bin
 | 
						|
	@echo "\tDFU\t" $@
 | 
						|
	@../scripts/bin2dfu.py \
 | 
						|
		-i $(OBJ_DIR)/$(PROJECT).bin \
 | 
						|
		-o $(OBJ_DIR)/$(PROJECT).dfu \
 | 
						|
		-a $(FLASH_ADDRESS) \
 | 
						|
		-l "Flipper Zero $(shell echo $(TARGET) | tr a-z A-Z)" > /dev/null
 | 
						|
 | 
						|
$(OBJ_DIR)/$(PROJECT).json: $(OBJ_DIR)/$(PROJECT).dfu
 | 
						|
	@echo "\tJSON\t" $@
 | 
						|
	@$(PROJECT_ROOT)/scripts/meta.py generate -p $(PROJECT) $(CFLAGS) > $(OBJ_DIR)/$(PROJECT).json
 | 
						|
 | 
						|
$(OBJ_DIR)/%.o: %.c $(OBJ_DIR)/BUILD_FLAGS
 | 
						|
	@echo "\tCC\t" $(subst $(PROJECT_ROOT)/, , $<)
 | 
						|
	@$(CC) $(CFLAGS) -c $< -o $@
 | 
						|
 | 
						|
$(OBJ_DIR)/%.o: %.s $(OBJ_DIR)/BUILD_FLAGS
 | 
						|
	@echo "\tASM\t" $(subst $(PROJECT_ROOT)/, , $<)
 | 
						|
	@$(AS) $(CFLAGS) -c $< -o $@
 | 
						|
 | 
						|
$(OBJ_DIR)/%.o: %.cpp $(OBJ_DIR)/BUILD_FLAGS
 | 
						|
	@echo "\tCPP\t" $(subst $(PROJECT_ROOT)/, , $<)
 | 
						|
	@$(CPP) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
 | 
						|
 | 
						|
$(OBJ_DIR)/flash: $(OBJ_DIR)/$(PROJECT).bin
 | 
						|
	openocd $(OPENOCD_OPTS) -c "program $(OBJ_DIR)/$(PROJECT).bin reset exit $(FLASH_ADDRESS)" 
 | 
						|
	touch $@
 | 
						|
 | 
						|
$(OBJ_DIR)/upload: $(OBJ_DIR)/$(PROJECT).bin
 | 
						|
	dfu-util -d 0483:df11 -D $(OBJ_DIR)/$(PROJECT).bin -a 0 -s $(FLASH_ADDRESS) $(DFU_OPTIONS)
 | 
						|
	touch $@
 | 
						|
 | 
						|
.PHONY: flash
 | 
						|
flash: $(OBJ_DIR)/flash
 | 
						|
 | 
						|
.PHONY: upload
 | 
						|
upload: $(OBJ_DIR)/upload
 | 
						|
 | 
						|
.PHONY: debug
 | 
						|
debug: flash
 | 
						|
	$(GDB) \
 | 
						|
		-ex 'target extended-remote | openocd -c "gdb_port pipe" $(OPENOCD_OPTS)' \
 | 
						|
		-ex "set confirm off" \
 | 
						|
		-ex "source ../debug/FreeRTOS/FreeRTOS.py" \
 | 
						|
		-ex "source ../debug/PyCortexMDebug/PyCortexMDebug.py" \
 | 
						|
		-ex "svd_load $(SVD_FILE)" \
 | 
						|
		-ex "compare-sections" \
 | 
						|
		$(OBJ_DIR)/$(PROJECT).elf; \
 | 
						|
 | 
						|
.PHONY: debug_other
 | 
						|
debug_other:
 | 
						|
	$(GDB) \
 | 
						|
		-ex 'target extended-remote | openocd -c "gdb_port pipe" $(OPENOCD_OPTS)' \
 | 
						|
		-ex "set confirm off" \
 | 
						|
		-ex "source ../debug/PyCortexMDebug/PyCortexMDebug.py" \
 | 
						|
		-ex "svd_load $(SVD_FILE)" \
 | 
						|
 | 
						|
.PHONY: blackmagic
 | 
						|
blackmagic:
 | 
						|
	$(GDB) \
 | 
						|
		-ex 'target extended-remote $(BLACKMAGIC)' \
 | 
						|
		-ex 'monitor swdp_scan' \
 | 
						|
		-ex 'monitor debug_bmp enable' \
 | 
						|
		-ex 'attach 1' \
 | 
						|
		-ex 'set confirm off' \
 | 
						|
		-ex 'set mem inaccessible-by-default off' \
 | 
						|
		-ex "source ../debug/FreeRTOS/FreeRTOS.py" \
 | 
						|
		-ex "source ../debug/PyCortexMDebug/PyCortexMDebug.py" \
 | 
						|
		-ex "svd_load $(SVD_FILE)" \
 | 
						|
		-ex "compare-sections" \
 | 
						|
		$(OBJ_DIR)/$(PROJECT).elf; \
 | 
						|
 | 
						|
.PHONY: openocd
 | 
						|
openocd:
 | 
						|
	openocd $(OPENOCD_OPTS)
 | 
						|
 | 
						|
.PHONY: clean
 | 
						|
clean:
 | 
						|
	@echo "\tCLEAN\t"
 | 
						|
	@$(RM) -rf $(OBJ_DIR)
 | 
						|
 | 
						|
.PHONY: z
 | 
						|
z: clean
 | 
						|
	$(MAKE) all
 | 
						|
 | 
						|
.PHONY: zz
 | 
						|
zz: clean
 | 
						|
	$(MAKE) flash
 | 
						|
 | 
						|
.PHONY: zzz
 | 
						|
zzz: clean
 | 
						|
	$(MAKE) debug
 | 
						|
 | 
						|
.PHONY: generate_cscope_db
 | 
						|
generate_cscope_db:
 | 
						|
	@echo "$(C_SOURCES) $(CPP_SOURCES) $(ASM_SOURCES)" | tr ' ' '\n' > $(OBJ_DIR)/source.list.p
 | 
						|
	@cat ~/headers.list >> $(OBJ_DIR)/source.list.p
 | 
						|
	@cat $(OBJ_DIR)/source.list.p | sed -e "s|^[^//]|$$PWD/&|g" > $(OBJ_DIR)/source.list
 | 
						|
	@cscope -b -k -i $(OBJ_DIR)/source.list -f $(OBJ_DIR)/cscope.out
 | 
						|
	@rm -rf $(OBJ_DIR)/source.list $(OBJ_DIR)/source.list.p
 | 
						|
 | 
						|
.PHONY: generate_compile_db
 | 
						|
generate_compile_db:
 | 
						|
	@echo "$(ASM_SOURCES)" | tr ' ' '\n' > $(OBJ_DIR)/db.asm_source.list
 | 
						|
	@echo "$(C_SOURCES)" | tr ' ' '\n' > $(OBJ_DIR)/db.c_source.list
 | 
						|
	@echo "$(CPP_SOURCES)" | tr ' ' '\n' > $(OBJ_DIR)/db.cpp_source.list
 | 
						|
	@echo "$(AS)$(CFLAGS)" | tr ' ' '\n' > $(OBJ_DIR)/db.asm_flags.list
 | 
						|
	@echo "$(CC)$(CFLAGS)" | tr ' ' '\n' > $(OBJ_DIR)/db.c_flags.list
 | 
						|
	@echo "$(CPP)$(CFLAGS)$(CPPFLAGS)" | tr ' ' '\n' > $(OBJ_DIR)/db.cpp_flags.list
 | 
						|
	@$(PROJECT_ROOT)/scripts/compile_db.py generate -p $(OBJ_DIR)
 | 
						|
	@rm $(OBJ_DIR)/db.asm_source.list
 | 
						|
	@rm $(OBJ_DIR)/db.c_source.list
 | 
						|
	@rm $(OBJ_DIR)/db.cpp_source.list
 | 
						|
	@rm $(OBJ_DIR)/db.asm_flags.list
 | 
						|
	@rm $(OBJ_DIR)/db.c_flags.list
 | 
						|
	@rm $(OBJ_DIR)/db.cpp_flags.list
 | 
						|
 | 
						|
# Prevent make from searching targets for real files
 | 
						|
%.d: ;
 | 
						|
 | 
						|
%.c: ;
 | 
						|
 | 
						|
%.cpp: ;
 | 
						|
 | 
						|
%.s: ;
 | 
						|
 | 
						|
$(OBJ_DIR)/BUILD_FLAGS: ;
 | 
						|
 | 
						|
-include $(DEPS)
 |