build_keyboard.mk 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421
  1. # Determine what keyboard we are building and setup the build environment.
  2. #
  3. # We support folders up to 5 levels deep below `keyboards/`. This file is
  4. # responsible for determining which folder is being used and doing the
  5. # corresponding environment setup.
  6. ifndef VERBOSE
  7. .SILENT:
  8. endif
  9. .DEFAULT_GOAL := all
  10. include common.mk
  11. # Set the qmk cli to use
  12. QMK_BIN ?= qmk
  13. # Set the filename for the final firmware binary
  14. KEYBOARD_FILESAFE := $(subst /,_,$(KEYBOARD))
  15. TARGET ?= $(KEYBOARD_FILESAFE)_$(KEYMAP)
  16. KEYBOARD_OUTPUT := $(BUILD_DIR)/obj_$(KEYBOARD_FILESAFE)
  17. # Force expansion
  18. TARGET := $(TARGET)
  19. # For split boards we need to set a master half.
  20. MASTER ?= left
  21. ifdef master
  22. MASTER = $(master)
  23. endif
  24. ifeq ($(MASTER),right)
  25. OPT_DEFS += -DMASTER_IS_ON_RIGHT
  26. else
  27. ifneq ($(MASTER),left)
  28. $(error MASTER does not have a valid value(left/right))
  29. endif
  30. endif
  31. ifdef SKIP_VERSION
  32. OPT_DEFS += -DSKIP_VERSION
  33. endif
  34. # Determine which subfolders exist.
  35. KEYBOARD_FOLDER_PATH_1 := $(KEYBOARD)
  36. KEYBOARD_FOLDER_PATH_2 := $(patsubst %/,%,$(dir $(KEYBOARD_FOLDER_PATH_1)))
  37. KEYBOARD_FOLDER_PATH_3 := $(patsubst %/,%,$(dir $(KEYBOARD_FOLDER_PATH_2)))
  38. KEYBOARD_FOLDER_PATH_4 := $(patsubst %/,%,$(dir $(KEYBOARD_FOLDER_PATH_3)))
  39. KEYBOARD_FOLDER_PATH_5 := $(patsubst %/,%,$(dir $(KEYBOARD_FOLDER_PATH_4)))
  40. KEYBOARD_FOLDER_1 := $(notdir $(KEYBOARD_FOLDER_PATH_1))
  41. KEYBOARD_FOLDER_2 := $(notdir $(KEYBOARD_FOLDER_PATH_2))
  42. KEYBOARD_FOLDER_3 := $(notdir $(KEYBOARD_FOLDER_PATH_3))
  43. KEYBOARD_FOLDER_4 := $(notdir $(KEYBOARD_FOLDER_PATH_4))
  44. KEYBOARD_FOLDER_5 := $(notdir $(KEYBOARD_FOLDER_PATH_5))
  45. KEYBOARD_PATHS :=
  46. KEYBOARD_PATH_1 := keyboards/$(KEYBOARD_FOLDER_PATH_1)
  47. KEYBOARD_PATH_2 := keyboards/$(KEYBOARD_FOLDER_PATH_2)
  48. KEYBOARD_PATH_3 := keyboards/$(KEYBOARD_FOLDER_PATH_3)
  49. KEYBOARD_PATH_4 := keyboards/$(KEYBOARD_FOLDER_PATH_4)
  50. KEYBOARD_PATH_5 := keyboards/$(KEYBOARD_FOLDER_PATH_5)
  51. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/)","")
  52. KEYBOARD_PATHS += $(KEYBOARD_PATH_5)
  53. endif
  54. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/)","")
  55. KEYBOARD_PATHS += $(KEYBOARD_PATH_4)
  56. endif
  57. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/)","")
  58. KEYBOARD_PATHS += $(KEYBOARD_PATH_3)
  59. endif
  60. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/)","")
  61. KEYBOARD_PATHS += $(KEYBOARD_PATH_2)
  62. endif
  63. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/)","")
  64. KEYBOARD_PATHS += $(KEYBOARD_PATH_1)
  65. endif
  66. # Pull in rules.mk files from all our subfolders
  67. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/rules.mk)","")
  68. include $(KEYBOARD_PATH_5)/rules.mk
  69. endif
  70. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/rules.mk)","")
  71. include $(KEYBOARD_PATH_4)/rules.mk
  72. endif
  73. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/rules.mk)","")
  74. include $(KEYBOARD_PATH_3)/rules.mk
  75. endif
  76. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/rules.mk)","")
  77. include $(KEYBOARD_PATH_2)/rules.mk
  78. endif
  79. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/rules.mk)","")
  80. include $(KEYBOARD_PATH_1)/rules.mk
  81. endif
  82. MAIN_KEYMAP_PATH_1 := $(KEYBOARD_PATH_1)/keymaps/$(KEYMAP)
  83. MAIN_KEYMAP_PATH_2 := $(KEYBOARD_PATH_2)/keymaps/$(KEYMAP)
  84. MAIN_KEYMAP_PATH_3 := $(KEYBOARD_PATH_3)/keymaps/$(KEYMAP)
  85. MAIN_KEYMAP_PATH_4 := $(KEYBOARD_PATH_4)/keymaps/$(KEYMAP)
  86. MAIN_KEYMAP_PATH_5 := $(KEYBOARD_PATH_5)/keymaps/$(KEYMAP)
  87. # Pull in rules from info.json
  88. INFO_RULES_MK = $(shell $(QMK_BIN) generate-rules-mk --quiet --escape --keyboard $(KEYBOARD) --output $(KEYBOARD_OUTPUT)/src/rules.mk)
  89. include $(INFO_RULES_MK)
  90. # Check for keymap.json first, so we can regenerate keymap.c
  91. include build_json.mk
  92. ifeq ("$(wildcard $(KEYMAP_PATH))", "")
  93. # Look through the possible keymap folders until we find a matching keymap.c
  94. ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_5)/keymap.c)","")
  95. -include $(MAIN_KEYMAP_PATH_5)/rules.mk
  96. KEYMAP_C := $(MAIN_KEYMAP_PATH_5)/keymap.c
  97. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_5)
  98. else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_4)/keymap.c)","")
  99. -include $(MAIN_KEYMAP_PATH_4)/rules.mk
  100. KEYMAP_C := $(MAIN_KEYMAP_PATH_4)/keymap.c
  101. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_4)
  102. else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_3)/keymap.c)","")
  103. -include $(MAIN_KEYMAP_PATH_3)/rules.mk
  104. KEYMAP_C := $(MAIN_KEYMAP_PATH_3)/keymap.c
  105. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_3)
  106. else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_2)/keymap.c)","")
  107. -include $(MAIN_KEYMAP_PATH_2)/rules.mk
  108. KEYMAP_C := $(MAIN_KEYMAP_PATH_2)/keymap.c
  109. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_2)
  110. else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_1)/keymap.c)","")
  111. -include $(MAIN_KEYMAP_PATH_1)/rules.mk
  112. KEYMAP_C := $(MAIN_KEYMAP_PATH_1)/keymap.c
  113. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_1)
  114. else ifneq ($(LAYOUTS),)
  115. # If we haven't found a keymap yet fall back to community layouts
  116. include build_layout.mk
  117. else
  118. $(error Could not find keymap)
  119. # this state should never be reached
  120. endif
  121. endif
  122. ifeq ($(strip $(CTPC)), yes)
  123. CONVERT_TO_PROTON_C=yes
  124. endif
  125. ifeq ($(strip $(CONVERT_TO_PROTON_C)), yes)
  126. include platforms/chibios/QMK_PROTON_C/convert_to_proton_c.mk
  127. endif
  128. ifneq ($(FORCE_LAYOUT),)
  129. TARGET := $(TARGET)_$(FORCE_LAYOUT)
  130. endif
  131. include quantum/mcu_selection.mk
  132. # Find all the C source files to be compiled in subfolders.
  133. KEYBOARD_SRC :=
  134. KEYBOARD_C_1 := $(KEYBOARD_PATH_1)/$(KEYBOARD_FOLDER_1).c
  135. KEYBOARD_C_2 := $(KEYBOARD_PATH_2)/$(KEYBOARD_FOLDER_2).c
  136. KEYBOARD_C_3 := $(KEYBOARD_PATH_3)/$(KEYBOARD_FOLDER_3).c
  137. KEYBOARD_C_4 := $(KEYBOARD_PATH_4)/$(KEYBOARD_FOLDER_4).c
  138. KEYBOARD_C_5 := $(KEYBOARD_PATH_5)/$(KEYBOARD_FOLDER_5).c
  139. ifneq ("$(wildcard $(KEYBOARD_C_5))","")
  140. KEYBOARD_SRC += $(KEYBOARD_C_5)
  141. endif
  142. ifneq ("$(wildcard $(KEYBOARD_C_4))","")
  143. KEYBOARD_SRC += $(KEYBOARD_C_4)
  144. endif
  145. ifneq ("$(wildcard $(KEYBOARD_C_3))","")
  146. KEYBOARD_SRC += $(KEYBOARD_C_3)
  147. endif
  148. ifneq ("$(wildcard $(KEYBOARD_C_2))","")
  149. KEYBOARD_SRC += $(KEYBOARD_C_2)
  150. endif
  151. ifneq ("$(wildcard $(KEYBOARD_C_1))","")
  152. KEYBOARD_SRC += $(KEYBOARD_C_1)
  153. endif
  154. # Generate KEYBOARD_name_subname for all levels of the keyboard folder
  155. KEYBOARD_FILESAFE_1 := $(subst .,,$(subst /,_,$(KEYBOARD_FOLDER_PATH_1)))
  156. KEYBOARD_FILESAFE_2 := $(subst .,,$(subst /,_,$(KEYBOARD_FOLDER_PATH_2)))
  157. KEYBOARD_FILESAFE_3 := $(subst .,,$(subst /,_,$(KEYBOARD_FOLDER_PATH_3)))
  158. KEYBOARD_FILESAFE_4 := $(subst .,,$(subst /,_,$(KEYBOARD_FOLDER_PATH_4)))
  159. KEYBOARD_FILESAFE_5 := $(subst .,,$(subst /,_,$(KEYBOARD_FOLDER_PATH_5)))
  160. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/)","")
  161. OPT_DEFS += -DKEYBOARD_$(KEYBOARD_FILESAFE_5)
  162. endif
  163. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/)","")
  164. OPT_DEFS += -DKEYBOARD_$(KEYBOARD_FILESAFE_4)
  165. endif
  166. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/)","")
  167. OPT_DEFS += -DKEYBOARD_$(KEYBOARD_FILESAFE_3)
  168. endif
  169. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/)","")
  170. OPT_DEFS += -DKEYBOARD_$(KEYBOARD_FILESAFE_2)
  171. endif
  172. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/)","")
  173. OPT_DEFS += -DKEYBOARD_$(KEYBOARD_FILESAFE_1)
  174. endif
  175. # Setup the define for QMK_KEYBOARD_H. This is used inside of keymaps so
  176. # that the same keymap may be used on multiple keyboards.
  177. #
  178. # We grab the most top-level include file that we can. That file should
  179. # use #ifdef statements to include all the neccesary subfolder includes,
  180. # as described here:
  181. #
  182. # https://docs.qmk.fm/#/feature_layouts?id=tips-for-making-layouts-keyboard-agnostic
  183. #
  184. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/$(KEYBOARD_FOLDER_1).h)","")
  185. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_1).h
  186. endif
  187. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/$(KEYBOARD_FOLDER_2).h)","")
  188. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_2).h
  189. endif
  190. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/$(KEYBOARD_FOLDER_3).h)","")
  191. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_3).h
  192. endif
  193. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/$(KEYBOARD_FOLDER_4).h)","")
  194. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_4).h
  195. endif
  196. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/$(KEYBOARD_FOLDER_5).h)","")
  197. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_5).h
  198. endif
  199. # Determine and set parameters based on the keyboard's processor family.
  200. # We can assume a ChibiOS target When MCU_FAMILY is defined since it's
  201. # not used for LUFA
  202. ifdef MCU_FAMILY
  203. PLATFORM=CHIBIOS
  204. PLATFORM_KEY=chibios
  205. FIRMWARE_FORMAT?=bin
  206. else ifdef ARM_ATSAM
  207. PLATFORM=ARM_ATSAM
  208. PLATFORM_KEY=arm_atsam
  209. FIRMWARE_FORMAT=bin
  210. else
  211. PLATFORM=AVR
  212. PLATFORM_KEY=avr
  213. FIRMWARE_FORMAT?=hex
  214. endif
  215. # Find all of the config.h files and add them to our CONFIG_H define.
  216. CONFIG_H :=
  217. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/config.h)","")
  218. CONFIG_H += $(KEYBOARD_PATH_5)/config.h
  219. endif
  220. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/config.h)","")
  221. CONFIG_H += $(KEYBOARD_PATH_4)/config.h
  222. endif
  223. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/config.h)","")
  224. CONFIG_H += $(KEYBOARD_PATH_3)/config.h
  225. endif
  226. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/config.h)","")
  227. CONFIG_H += $(KEYBOARD_PATH_2)/config.h
  228. endif
  229. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/config.h)","")
  230. CONFIG_H += $(KEYBOARD_PATH_1)/config.h
  231. endif
  232. POST_CONFIG_H :=
  233. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/post_config.h)","")
  234. POST_CONFIG_H += $(KEYBOARD_PATH_1)/post_config.h
  235. endif
  236. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/post_config.h)","")
  237. POST_CONFIG_H += $(KEYBOARD_PATH_2)/post_config.h
  238. endif
  239. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/post_config.h)","")
  240. POST_CONFIG_H += $(KEYBOARD_PATH_3)/post_config.h
  241. endif
  242. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/post_config.h)","")
  243. POST_CONFIG_H += $(KEYBOARD_PATH_4)/post_config.h
  244. endif
  245. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/post_config.h)","")
  246. POST_CONFIG_H += $(KEYBOARD_PATH_5)/post_config.h
  247. endif
  248. # Pull in stuff from info.json
  249. INFO_JSON_FILES :=
  250. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/info.json)","")
  251. INFO_JSON_FILES += $(KEYBOARD_PATH_1)/info.json
  252. endif
  253. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/info.json)","")
  254. INFO_JSON_FILES += $(KEYBOARD_PATH_2)/info.json
  255. endif
  256. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/info.json)","")
  257. INFO_JSON_FILES += $(KEYBOARD_PATH_3)/info.json
  258. endif
  259. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/info.json)","")
  260. INFO_JSON_FILES += $(KEYBOARD_PATH_4)/info.json
  261. endif
  262. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/info.json)","")
  263. INFO_JSON_FILES += $(KEYBOARD_PATH_5)/info.json
  264. endif
  265. CONFIG_H += $(KEYBOARD_OUTPUT)/src/info_config.h $(KEYBOARD_OUTPUT)/src/layouts.h
  266. $(KEYBOARD_OUTPUT)/src/info_config.h: $(INFO_JSON_FILES)
  267. $(QMK_BIN) generate-config-h --quiet --keyboard $(KEYBOARD) --output $(KEYBOARD_OUTPUT)/src/info_config.h
  268. $(KEYBOARD_OUTPUT)/src/layouts.h: $(INFO_JSON_FILES)
  269. $(QMK_BIN) generate-layouts --quiet --keyboard $(KEYBOARD) --output $(KEYBOARD_OUTPUT)/src/layouts.h
  270. generated-files: $(KEYBOARD_OUTPUT)/src/info_config.h $(KEYBOARD_OUTPUT)/src/layouts.h
  271. .INTERMEDIATE : generated-files
  272. # Userspace setup and definitions
  273. ifeq ("$(USER_NAME)","")
  274. USER_NAME := $(KEYMAP)
  275. endif
  276. USER_PATH := users/$(USER_NAME)
  277. -include $(USER_PATH)/rules.mk
  278. ifneq ("$(wildcard $(USER_PATH)/config.h)","")
  279. CONFIG_H += $(USER_PATH)/config.h
  280. endif
  281. ifneq ("$(wildcard $(USER_PATH)/post_config.h)","")
  282. POST_CONFIG_H += $(USER_PATH)/post_config.h
  283. endif
  284. # Disable features that a keyboard doesn't support
  285. -include disable_features.mk
  286. # Object files directory
  287. # To put object files in current directory, use a dot (.), do NOT make
  288. # this an empty or blank macro!
  289. KEYMAP_OUTPUT := $(BUILD_DIR)/obj_$(TARGET)
  290. ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","")
  291. CONFIG_H += $(KEYMAP_PATH)/config.h
  292. endif
  293. # project specific files
  294. SRC += $(KEYBOARD_SRC) \
  295. $(KEYMAP_C) \
  296. $(QUANTUM_SRC)
  297. # Optimize size but this may cause error "relocation truncated to fit"
  298. #EXTRALDFLAGS = -Wl,--relax
  299. # Search Path
  300. VPATH += $(KEYMAP_PATH)
  301. VPATH += $(USER_PATH)
  302. VPATH += $(KEYBOARD_PATHS)
  303. VPATH += $(COMMON_VPATH)
  304. include common_features.mk
  305. include $(TMK_PATH)/protocol.mk
  306. include $(TMK_PATH)/common.mk
  307. include bootloader.mk
  308. SRC += $(patsubst %.c,%.clib,$(LIB_SRC))
  309. SRC += $(patsubst %.c,%.clib,$(QUANTUM_LIB_SRC))
  310. SRC += $(TMK_COMMON_SRC)
  311. OPT_DEFS += $(TMK_COMMON_DEFS)
  312. EXTRALDFLAGS += $(TMK_COMMON_LDFLAGS)
  313. SKIP_COMPILE := no
  314. ifneq ($(REQUIRE_PLATFORM_KEY),)
  315. ifneq ($(REQUIRE_PLATFORM_KEY),$(PLATFORM_KEY))
  316. SKIP_COMPILE := yes
  317. endif
  318. endif
  319. include $(TMK_PATH)/$(PLATFORM_KEY).mk
  320. ifneq ($(strip $(PROTOCOL)),)
  321. include $(TMK_PATH)/protocol/$(strip $(shell echo $(PROTOCOL) | tr '[:upper:]' '[:lower:]')).mk
  322. else
  323. include $(TMK_PATH)/protocol/$(PLATFORM_KEY).mk
  324. endif
  325. # TODO: remove this bodge?
  326. PROJECT_DEFS := $(OPT_DEFS)
  327. PROJECT_INC := $(VPATH) $(EXTRAINCDIRS) $(KEYBOARD_PATHS)
  328. PROJECT_CONFIG := $(CONFIG_H)
  329. ifeq ($(strip $(VISUALIZER_ENABLE)), yes)
  330. VISUALIZER_DIR = $(QUANTUM_DIR)/visualizer
  331. VISUALIZER_PATH = $(QUANTUM_PATH)/visualizer
  332. include $(VISUALIZER_PATH)/visualizer.mk
  333. endif
  334. CONFIG_H += $(POST_CONFIG_H)
  335. ALL_CONFIGS := $(PROJECT_CONFIG) $(CONFIG_H)
  336. OUTPUTS := $(KEYMAP_OUTPUT) $(KEYBOARD_OUTPUT)
  337. $(KEYMAP_OUTPUT)_SRC := $(SRC)
  338. $(KEYMAP_OUTPUT)_DEFS := $(OPT_DEFS) $(GFXDEFS) \
  339. -DQMK_KEYBOARD=\"$(KEYBOARD)\" -DQMK_KEYBOARD_H=\"$(QMK_KEYBOARD_H)\" \
  340. -DQMK_KEYMAP=\"$(KEYMAP)\" -DQMK_KEYMAP_H=\"$(KEYMAP).h\" -DQMK_KEYMAP_CONFIG_H=\"$(KEYMAP_PATH)/config.h\" \
  341. -DQMK_SUBPROJECT -DQMK_SUBPROJECT_H -DQMK_SUBPROJECT_CONFIG_H
  342. $(KEYMAP_OUTPUT)_INC := $(VPATH) $(EXTRAINCDIRS)
  343. $(KEYMAP_OUTPUT)_CONFIG := $(CONFIG_H)
  344. $(KEYBOARD_OUTPUT)_SRC := $(CHIBISRC) $(GFXSRC)
  345. $(KEYBOARD_OUTPUT)_DEFS := $(PROJECT_DEFS) $(GFXDEFS)
  346. $(KEYBOARD_OUTPUT)_INC := $(PROJECT_INC) $(GFXINC)
  347. $(KEYBOARD_OUTPUT)_CONFIG := $(PROJECT_CONFIG)
  348. # Default target.
  349. ifeq ($(SKIP_COMPILE),no)
  350. all: build check-size
  351. else
  352. all:
  353. echo "skipped" >&2
  354. endif
  355. build: elf cpfirmware
  356. check-size: build
  357. check-md5: build
  358. objs-size: build
  359. include show_options.mk
  360. include $(TMK_PATH)/rules.mk
  361. # Ensure we have generated files available for each of the objects
  362. define GEN_FILES
  363. $1: generated-files
  364. endef
  365. $(foreach O,$(OBJ),$(eval $(call GEN_FILES,$(patsubst %.a,%.o,$(O)))))