logo

qmk_firmware

custom branch of QMK firmware git clone https://anongit.hacktivis.me/git/qmk_firmware.git

common_rules.mk (13116B)


  1. # Hey Emacs, this is a -*- makefile -*-
  2. #----------------------------------------------------------------------------
  3. # Enable vpath searching for source files only
  4. # Without this, output files, could be read from the wrong .build directories
  5. VPATH_SRC := $(VPATH)
  6. vpath %.c $(VPATH_SRC)
  7. vpath %.h $(VPATH_SRC)
  8. vpath %.cpp $(VPATH_SRC)
  9. vpath %.cc $(VPATH_SRC)
  10. vpath %.hpp $(VPATH_SRC)
  11. vpath %.S $(VPATH_SRC)
  12. VPATH :=
  13. # Helper to return the distinct elements of a list
  14. uniq = $(if $1,$(firstword $1) $(call uniq,$(filter-out $(firstword $1),$1)))
  15. # Convert all SRC to OBJ
  16. define OBJ_FROM_SRC
  17. $(patsubst %.c,$1/%.o,$(patsubst %.cpp,$1/%.o,$(patsubst %.cc,$1/%.o,$(patsubst %.S,$1/%.o,$(patsubst %.clib,$1/%.a,$($1_SRC))))))
  18. endef
  19. $(foreach OUTPUT,$(OUTPUTS),$(eval $(OUTPUT)_OBJ +=$(call OBJ_FROM_SRC,$(OUTPUT))))
  20. # Define a list of all objects
  21. OBJ := $(foreach OUTPUT,$(OUTPUTS),$($(OUTPUT)_OBJ))
  22. NO_LTO_OBJ := $(filter %.a,$(OBJ))
  23. MASTER_OUTPUT := $(firstword $(OUTPUTS))
  24. # Output format. (can be srec, ihex, binary)
  25. FORMAT = ihex
  26. # Optimization level, can be [0, 1, 2, 3, s].
  27. OPT ?= s
  28. # Compiler flag to set the C and C++ language standard level
  29. CSTANDARD = -std=gnu11
  30. CXXSTANDARD = -std=gnu++14
  31. # Speed up recompilations by opt-in usage of ccache
  32. USE_CCACHE ?= no
  33. ifneq ($(USE_CCACHE),no)
  34. CC_PREFIX ?= ccache
  35. endif
  36. #---------------- Debug Options ----------------
  37. DEBUG_ENABLE ?= no
  38. ifeq ($(strip $(DEBUG_ENABLE)),yes)
  39. CFLAGS += -ggdb3
  40. CXXFLAGS += -ggdb3
  41. ASFLAGS += -ggdb3
  42. # Create a map file when debugging
  43. LDFLAGS += -Wl,-Map=$(BUILD_DIR)/$(TARGET).map,--cref
  44. endif
  45. #---------------- C Compiler Options ----------------
  46. ifeq ($(strip $(LTO_ENABLE)), yes)
  47. CDEFS += -flto
  48. CDEFS += -DLTO_ENABLE
  49. endif
  50. CFLAGS += $(CDEFS)
  51. CFLAGS += -O$(OPT)
  52. # add color
  53. ifeq ($(COLOR),true)
  54. ifeq ("$(shell echo "int main(){}" | $(CC) -fdiagnostics-color -x c - -o /dev/null 2>&1)", "")
  55. CFLAGS+= -fdiagnostics-color
  56. endif
  57. endif
  58. CFLAGS += -Wall
  59. CFLAGS += -Wstrict-prototypes
  60. ifneq ($(strip $(ALLOW_WARNINGS)), yes)
  61. CFLAGS += -Werror
  62. endif
  63. CFLAGS += $(CSTANDARD)
  64. # This fixes lots of keyboards linking errors but SHOULDN'T BE A FINAL SOLUTION
  65. # Fixing of multiple variable definitions must be made.
  66. CFLAGS += -fcommon
  67. #---------------- C++ Compiler Options ----------------
  68. CXXFLAGS += $(CXXDEFS)
  69. CXXFLAGS += -O$(OPT)
  70. # to suppress "warning: only initialized variables can be placed into program memory area"
  71. CXXFLAGS += -w
  72. CXXFLAGS += -Wall
  73. CXXFLAGS += -Wundef
  74. ifneq ($(strip $(ALLOW_WARNINGS)), yes)
  75. CXXFLAGS += -Werror
  76. endif
  77. #---------------- Assembler Options ----------------
  78. ASFLAGS += $(ADEFS)
  79. ifeq ($(VERBOSE_AS_CMD),yes)
  80. ASFLAGS += -v
  81. endif
  82. #---------------- Linker Options ----------------
  83. ifeq ($(VERBOSE_LD_CMD),yes)
  84. LDFLAGS += -v
  85. endif
  86. LDFLAGS += $(EXTMEMOPTS)
  87. LDFLAGS += $(patsubst %,-L%,$(EXTRALIBDIRS))
  88. LDFLAGS += -lm
  89. # You can give EXTRALDFLAGS at 'make' command line.
  90. LDFLAGS += $(EXTRALDFLAGS)
  91. #---------------- Assembler Listings ----------------
  92. ADHLNS_ENABLE ?= no
  93. ifeq ($(ADHLNS_ENABLE),yes)
  94. # Avoid "Options to '-Xassembler' do not match" - only specify assembler options at LTO link time
  95. ifeq ($(strip $(LTO_ENABLE)), yes)
  96. LDFLAGS += -Wa,-adhlns=$(BUILD_DIR)/$(TARGET).lst
  97. else
  98. CFLAGS += -Wa,-adhlns=$(@:%.o=%.lst)
  99. CXXFLAGS += -Wa,-adhlns=$(@:%.o=%.lst)
  100. ASFLAGS += -Wa,-adhlns=$(@:%.o=%.lst),--listing-cont-lines=100
  101. endif
  102. endif
  103. # Define programs and commands.
  104. SHELL = sh
  105. SED = sed
  106. REMOVE = rm -f
  107. REMOVEDIR = rmdir
  108. COPY = cp
  109. WINSHELL = cmd
  110. SECHO = $(SILENT) || echo
  111. MD5SUM ?= md5sum
  112. ifneq ($(filter Darwin FreeBSD,$(shell uname -s)),)
  113. MD5SUM = md5
  114. endif
  115. # UF2 format settings
  116. # To produce a UF2 file in your build, add to your keyboard's rules.mk:
  117. # FIRMWARE_FORMAT = uf2
  118. UF2CONV = $(TOP_DIR)/util/uf2conv.py
  119. UF2CONV_ARGS ?=
  120. UF2_FAMILY ?= 0x0
  121. # Compiler flags to generate dependency files.
  122. #GENDEPFLAGS = -MMD -MP -MF .dep/$(@F).d
  123. GENDEPFLAGS = -MMD -MP -MF $(patsubst %.o,%.td,$@)
  124. # Combine all necessary flags and optional flags.
  125. # Add target processor to flags.
  126. # You can give extra flags at 'make' command line like: make EXTRAFLAGS=-DFOO=bar
  127. ALL_CFLAGS = $(MCUFLAGS) $(CFLAGS) $(EXTRAFLAGS)
  128. ALL_CXXFLAGS = $(MCUFLAGS) -x c++ $(CXXFLAGS) $(EXTRAFLAGS)
  129. ALL_ASFLAGS = $(MCUFLAGS) -x assembler-with-cpp $(ASFLAGS) $(EXTRAFLAGS)
  130. define NO_LTO
  131. $(patsubst %.a,%.o,$1): NOLTO_CFLAGS += -fno-lto
  132. endef
  133. $(foreach LOBJ, $(NO_LTO_OBJ), $(eval $(call NO_LTO,$(LOBJ))))
  134. MOVE_DEP = mv -f $(patsubst %.o,%.td,$@) $(patsubst %.o,%.d,$@)
  135. # For a ChibiOS build, ensure that the board files have the hook overrides injected
  136. define BOARDSRC_INJECT_HOOKS
  137. $(INTERMEDIATE_OUTPUT)/$(patsubst %.c,%.o,$(patsubst ./%,%,$1)): FILE_SPECIFIC_CFLAGS += -include $(TOP_DIR)/tmk_core/protocol/chibios/init_hooks.h
  138. endef
  139. $(foreach LOBJ, $(BOARDSRC), $(eval $(call BOARDSRC_INJECT_HOOKS,$(LOBJ))))
  140. # Add QMK specific flags
  141. DFU_SUFFIX ?= dfu-suffix
  142. DFU_SUFFIX_ARGS ?=
  143. elf: $(BUILD_DIR)/$(TARGET).elf
  144. hex: $(BUILD_DIR)/$(TARGET).hex
  145. uf2: $(BUILD_DIR)/$(TARGET).uf2
  146. cpfirmware_qmk: $(FIRMWARE_FORMAT)
  147. $(SILENT) || printf "Copying $(TARGET).$(FIRMWARE_FORMAT) to qmk_firmware folder" | $(AWK_CMD)
  148. $(COPY) $(BUILD_DIR)/$(TARGET).$(FIRMWARE_FORMAT) $(TARGET).$(FIRMWARE_FORMAT) && $(PRINT_OK)
  149. eep: $(BUILD_DIR)/$(TARGET).eep
  150. lss: $(BUILD_DIR)/$(TARGET).lss
  151. sym: $(BUILD_DIR)/$(TARGET).sym
  152. LIBNAME=lib$(TARGET).a
  153. lib: $(LIBNAME)
  154. cpfirmware: cpfirmware_qmk
  155. ifneq ($(QMK_USERSPACE),)
  156. cpfirmware: cpfirmware_userspace
  157. cpfirmware_userspace: cpfirmware_qmk
  158. $(SILENT) || printf "Copying $(TARGET).$(FIRMWARE_FORMAT) to userspace folder" | $(AWK_CMD)
  159. $(COPY) $(BUILD_DIR)/$(TARGET).$(FIRMWARE_FORMAT) $(QMK_USERSPACE)/$(TARGET).$(FIRMWARE_FORMAT) && $(PRINT_OK)
  160. endif
  161. # Display size of file, modifying the output so people don't mistakenly grab the hex output
  162. BINARY_SIZE = $(SIZE) --target=$(FORMAT) $(BUILD_DIR)/$(TARGET).hex | $(SED) -e 's/\.build\/.*$$/$(TARGET).$(FIRMWARE_FORMAT)/g'
  163. sizebefore:
  164. @if test -f $(BUILD_DIR)/$(TARGET).hex; then $(SECHO) $(MSG_SIZE_BEFORE); $(SILENT) || $(BINARY_SIZE); \
  165. 2>/dev/null; $(SECHO); fi
  166. sizeafter: $(BUILD_DIR)/$(TARGET).hex
  167. @if test -f $(BUILD_DIR)/$(TARGET).hex; then $(SECHO); $(SECHO) $(MSG_SIZE_AFTER); $(SILENT) || $(BINARY_SIZE); \
  168. 2>/dev/null; $(SECHO); fi
  169. # Display compiler version information.
  170. gccversion :
  171. @$(SILENT) || $(CC) --version
  172. # Create final output files (.hex, .eep) from ELF output file.
  173. %.hex: %.elf
  174. $(eval CMD=$(HEX) $< $@)
  175. #@$(SILENT) || printf "$(MSG_EXECUTING) '$(CMD)':\n"
  176. @$(SILENT) || printf "$(MSG_FLASH) $@" | $(AWK_CMD)
  177. @$(BUILD_CMD)
  178. %.uf2: %.elf
  179. $(eval CMD=$(HEX) $< $(BUILD_DIR)/$(TARGET).tmp && $(UF2CONV) $(UF2CONV_ARGS) $(BUILD_DIR)/$(TARGET).tmp --output $@ --convert --family $(UF2_FAMILY) >/dev/null 2>&1)
  180. #@$(SILENT) || printf "$(MSG_EXECUTING) '$(CMD)':\n"
  181. @$(SILENT) || printf "$(MSG_UF2) $@" | $(AWK_CMD)
  182. @$(BUILD_CMD)
  183. %.eep: %.elf
  184. $(eval CMD=$(EEP) $< $@ || exit 0)
  185. #@$(SILENT) || printf "$(MSG_EXECUTING) '$(CMD)':\n"
  186. @$(SILENT) || printf "$(MSG_EEPROM) $@" | $(AWK_CMD)
  187. @$(BUILD_CMD)
  188. # Create extended listing file from ELF output file.
  189. %.lss: %.elf
  190. $(eval CMD=$(OBJDUMP) -h -S -z $< > $@)
  191. #@$(SILENT) || printf "$(MSG_EXECUTING) '$(CMD)':\n"
  192. @$(SILENT) || printf "$(MSG_EXTENDED_LISTING) $@" | $(AWK_CMD)
  193. @$(BUILD_CMD)
  194. # Create a symbol table from ELF output file.
  195. %.sym: %.elf
  196. $(eval CMD=$(NM) -n $< > $@ )
  197. #@$(SILENT) || printf "$(MSG_EXECUTING) '$(CMD)':\n"
  198. @$(SILENT) || printf "$(MSG_SYMBOL_TABLE) $@" | $(AWK_CMD)
  199. @$(BUILD_CMD)
  200. %.bin: %.elf
  201. $(eval CMD=$(BIN) $< $@ || exit 0)
  202. #@$(SILENT) || printf "$(MSG_EXECUTING) '$(CMD)':\n"
  203. @$(SILENT) || printf "$(MSG_BIN) $@" | $(AWK_CMD)
  204. @$(BUILD_CMD)
  205. if [ ! -z "$(DFU_SUFFIX_ARGS)" ]; then \
  206. $(DFU_SUFFIX) $(DFU_SUFFIX_ARGS) -a $(BUILD_DIR)/$(TARGET).bin 1>/dev/null ;\
  207. fi
  208. #$(SILENT) || printf "$(MSG_EXECUTING) '$(DFU_SUFFIX) $(DFU_SUFFIX_ARGS) -a $(BUILD_DIR)/$(TARGET).bin 1>/dev/null':\n" ;\
  209. $(COPY) $(BUILD_DIR)/$(TARGET).bin $(TARGET).bin;
  210. BEGIN = gccversion sizebefore
  211. # Link: create ELF output file from object files.
  212. .SECONDARY : $(BUILD_DIR)/$(TARGET).elf
  213. .PRECIOUS : $(OBJ)
  214. # Note the obj.txt depeendency is there to force linking if a source file is deleted
  215. %.elf: $(OBJ) $(MASTER_OUTPUT)/cflags.txt $(MASTER_OUTPUT)/ldflags.txt $(MASTER_OUTPUT)/obj.txt | $(BEGIN)
  216. @$(SILENT) || printf "$(MSG_LINKING) $@" | $(AWK_CMD)
  217. $(eval CMD=MAKE=$(MAKE) $(CC) $(ALL_CFLAGS) $(call uniq,$(OBJ)) --output $@ $(LDFLAGS))
  218. @$(BUILD_CMD)
  219. define GEN_OBJRULE
  220. $1_INCFLAGS := $$(patsubst %,-I%,$$($1_INC))
  221. ifdef $1_CONFIG
  222. $1_CONFIG_FLAGS += $$(patsubst %,-include %,$$($1_CONFIG))
  223. endif
  224. $1_CFLAGS = $$(ALL_CFLAGS) $$($1_DEFS) $$($1_INCFLAGS) $$($1_CONFIG_FLAGS) $$(NOLTO_CFLAGS)
  225. $1_CXXFLAGS = $$(ALL_CXXFLAGS) $$($1_DEFS) $$($1_INCFLAGS) $$($1_CONFIG_FLAGS) $$(NOLTO_CFLAGS)
  226. $1_ASFLAGS = $$(ALL_ASFLAGS) $$($1_DEFS) $$($1_INCFLAGS) $$($1_CONFIG_FLAGS)
  227. # Compile: create object files from C source files.
  228. $1/%.o : %.c $1/%.d $1/cflags.txt $1/compiler.txt | $(BEGIN)
  229. @mkdir -p $$(@D)
  230. @$$(SILENT) || printf "$$(MSG_COMPILING) $$<" | $$(AWK_CMD)
  231. $$(eval CC_EXEC := $$(CC))
  232. ifneq ($$(VERBOSE_C_CMD),)
  233. $$(if $$(filter $$(notdir $$(VERBOSE_C_CMD)),$$(notdir $$<)),$$(eval CC_EXEC += -v))
  234. endif
  235. ifneq ($$(VERBOSE_C_INCLUDE),)
  236. $$(if $$(filter $$(notdir $$(VERBOSE_C_INCLUDE)),$$(notdir $$<)),$$(eval CC_EXEC += -H))
  237. endif
  238. $$(eval CMD := $$(CC_EXEC) -c $$($1_CFLAGS) $$(FILE_SPECIFIC_CFLAGS) $$(GENDEPFLAGS) $$< -o $$@ && $$(MOVE_DEP))
  239. @$$(BUILD_CMD)
  240. ifneq ($$(DUMP_C_MACROS),)
  241. $$(eval CMD := $$(CC) -E -dM $$($1_CFLAGS) $$(FILE_SPECIFIC_CFLAGS) $$(GENDEPFLAGS) $$<)
  242. @$$(if $$(filter $$(notdir $$(DUMP_C_MACROS)),$$(notdir $$<)),$$(BUILD_CMD))
  243. endif
  244. # Compile: create object files from C++ source files.
  245. $1/%.o : %.cpp $1/%.d $1/cxxflags.txt $1/compiler.txt | $(BEGIN)
  246. @mkdir -p $$(@D)
  247. @$$(SILENT) || printf "$$(MSG_COMPILING_CXX) $$<" | $$(AWK_CMD)
  248. $$(eval CMD=$$(CC) -c $$($1_CXXFLAGS) $$(FILE_SPECIFIC_CFLAGS) $$(GENDEPFLAGS) $$< -o $$@ && $$(MOVE_DEP))
  249. @$$(BUILD_CMD)
  250. $1/%.o : %.cc $1/%.d $1/cxxflags.txt $1/compiler.txt | $(BEGIN)
  251. @mkdir -p $$(@D)
  252. @$$(SILENT) || printf "$$(MSG_COMPILING_CXX) $$<" | $$(AWK_CMD)
  253. $$(eval CMD=$$(CC) -c $$($1_CXXFLAGS) $$(FILE_SPECIFIC_CFLAGS) $$(GENDEPFLAGS) $$< -o $$@ && $$(MOVE_DEP))
  254. @$$(BUILD_CMD)
  255. # Assemble: create object files from assembler source files.
  256. $1/%.o : %.S $1/asflags.txt $1/compiler.txt | $(BEGIN)
  257. @mkdir -p $$(@D)
  258. @$(SILENT) || printf "$$(MSG_ASSEMBLING) $$<" | $$(AWK_CMD)
  259. $$(eval CMD=$$(CC) -c $$($1_ASFLAGS) $$< -o $$@)
  260. @$$(BUILD_CMD)
  261. $1/%.a : $1/%.o
  262. @mkdir -p $$(@D)
  263. @$(SILENT) || printf "Archiving: $$<" | $$(AWK_CMD)
  264. $$(eval CMD=$$(AR) rcs $$@ $$<)
  265. @$$(BUILD_CMD)
  266. $1/force:
  267. $1/cflags.txt: $1/force
  268. echo '$$($1_CFLAGS)' | cmp -s - $$@ || echo '$$($1_CFLAGS)' > $$@
  269. $1/cxxflags.txt: $1/force
  270. echo '$$($1_CXXFLAGS)' | cmp -s - $$@ || echo '$$($1_CXXFLAGS)' > $$@
  271. $1/asflags.txt: $1/force
  272. echo '$$($1_ASFLAGS)' | cmp -s - $$@ || echo '$$($1_ASFLAGS)' > $$@
  273. $1/compiler.txt: $1/force
  274. test -f $$@ || touch $$@
  275. $$(CC) --version | cmp -s - $$@ || $$(CC) --version > $$@
  276. endef
  277. .PRECIOUS: $(MASTER_OUTPUT)/obj.txt
  278. $(MASTER_OUTPUT)/obj.txt: $(MASTER_OUTPUT)/force
  279. echo '$(OBJ)' | cmp -s - $@ || echo '$(OBJ)' > $@
  280. .PRECIOUS: $(MASTER_OUTPUT)/ldflags.txt
  281. $(MASTER_OUTPUT)/ldflags.txt: $(MASTER_OUTPUT)/force
  282. echo '$(LDFLAGS)' | cmp -s - $@ || echo '$(LDFLAGS)' > $@
  283. # We have to use static rules for the .d files for some reason
  284. DEPS = $(patsubst %.o,%.d,$(patsubst %.a,%.o,$(OBJ)))
  285. # Keep the .d files
  286. .PRECIOUS: $(DEPS)
  287. # Empty rule to force recompilation if the .d file is missing
  288. $(DEPS):
  289. $(foreach OUTPUT,$(OUTPUTS),$(eval $(call GEN_OBJRULE,$(OUTPUT))))
  290. # Create preprocessed source for use in sending a bug report.
  291. %.i : %.c | $(BEGIN)
  292. $(CC) -E -mmcu=$(MCU) $(CFLAGS) $< -o $@
  293. # Target: clean project.
  294. clean:
  295. $(foreach OUTPUT,$(OUTPUTS), $(REMOVE) -r $(OUTPUT) 2>/dev/null)
  296. $(REMOVE) $(BUILD_DIR)/$(TARGET).*
  297. show_path:
  298. @echo VPATH=$(VPATH)
  299. @echo SRC=$(SRC)
  300. @echo OBJ=$(OBJ)
  301. dump_vars: ERROR_IF_EMPTY=""
  302. dump_vars: ERROR_IF_NONBOOL=""
  303. dump_vars: ERROR_IF_UNSET=""
  304. dump_vars: CATASTROPHIC_ERROR=""
  305. dump_vars:
  306. @$(foreach V,$(sort $(.VARIABLES)),$(if $(filter-out environment% default automatic,$(origin $V)),$(info $V=$($V))))
  307. objs-size:
  308. for i in $(OBJ); do echo $$i; done | sort | xargs $(SIZE)
  309. # size check optionally implemented in its platform.mk
  310. check-size:
  311. check-md5:
  312. $(MD5SUM) $(BUILD_DIR)/$(TARGET).$(FIRMWARE_FORMAT)
  313. # Create build directory
  314. $(shell mkdir -p $(BUILD_DIR) 2>/dev/null)
  315. # Create object files directory
  316. $(eval $(foreach OUTPUT,$(OUTPUTS),$(shell mkdir -p $(OUTPUT) 2>/dev/null)))
  317. # Include the dependency files.
  318. -include $(patsubst %.o,%.d,$(patsubst %.a,%.o,$(OBJ)))
  319. # Listing of phony targets.
  320. .PHONY : all dump_vars finish sizebefore sizeafter qmkversion \
  321. gccversion build elf hex uf2 eep lss sym coff extcoff \
  322. clean clean_list debug gdb-config show_path \
  323. program teensy dfu dfu-ee dfu-start \
  324. flash dfu-split-left dfu-split-right \
  325. avrdude-split-left avrdude-split-right \
  326. avrdude-loop usbasp