chibios.mk 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. # Hey Emacs, this is a -*- makefile -*-
  2. ##############################################################################
  3. # Architecture or project specific options
  4. #
  5. # Stack size to be allocated to the Cortex-M process stack. This stack is
  6. # the stack used by the main() thread.
  7. ifeq ($(USE_PROCESS_STACKSIZE),)
  8. USE_PROCESS_STACKSIZE = 0x800
  9. endif
  10. # Stack size to the allocated to the Cortex-M main/exceptions stack. This
  11. # stack is used for processing interrupts and exceptions.
  12. ifeq ($(USE_EXCEPTIONS_STACKSIZE),)
  13. USE_EXCEPTIONS_STACKSIZE = 0x400
  14. endif
  15. #
  16. # Architecture or project specific options
  17. ##############################################################################
  18. ##############################################################################
  19. # Project, sources and paths
  20. #
  21. # Imported source files and paths
  22. OPT_OS = chibios
  23. CHIBIOS = $(TOP_DIR)/lib/chibios
  24. CHIBIOS_CONTRIB = $(TOP_DIR)/lib/chibios-contrib
  25. # Startup files. Try a few different locations, for compability with old versions and
  26. # for things hardware in the contrib repository
  27. STARTUP_MK = $(CHIBIOS)/os/common/ports/ARMCMx/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  28. ifeq ("$(wildcard $(STARTUP_MK))","")
  29. STARTUP_MK = $(CHIBIOS)/os/common/startup/ARMCMx/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  30. ifeq ("$(wildcard $(STARTUP_MK))","")
  31. STARTUP_MK = $(CHIBIOS_CONTRIB)/os/common/startup/ARMCMx/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  32. endif
  33. endif
  34. include $(STARTUP_MK)
  35. # HAL-OSAL files (optional).
  36. include $(CHIBIOS)/os/hal/hal.mk
  37. ifeq ("$(PLATFORM_NAME)","")
  38. PLATFORM_NAME = platform
  39. endif
  40. PLATFORM_MK = $(CHIBIOS)/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES)/$(PLATFORM_NAME).mk
  41. ifeq ("$(wildcard $(PLATFORM_MK))","")
  42. PLATFORM_MK = $(CHIBIOS_CONTRIB)/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES)/$(PLATFORM_NAME).mk
  43. endif
  44. include $(PLATFORM_MK)
  45. BOARD_MK :=
  46. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/boards/$(BOARD)/board.mk)","")
  47. BOARD_PATH = $(KEYBOARD_PATH_5)
  48. BOARD_MK += $(KEYBOARD_PATH_5)/boards/$(BOARD)/board.mk
  49. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/boards/$(BOARD)/board.mk)","")
  50. BOARD_PATH = $(KEYBOARD_PATH_4)
  51. BOARD_MK += $(KEYBOARD_PATH_4)/boards/$(BOARD)/board.mk
  52. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/boards/$(BOARD)/board.mk)","")
  53. BOARD_PATH = $(KEYBOARD_PATH_3)
  54. BOARD_MK += $(KEYBOARD_PATH_3)/boards/$(BOARD)/board.mk
  55. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/boards/$(BOARD)/board.mk)","")
  56. BOARD_PATH = $(KEYBOARD_PATH_2)
  57. BOARD_MK += $(KEYBOARD_PATH_2)/boards/$(BOARD)/board.mk
  58. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/boards/$(BOARD)/board.mk)","")
  59. BOARD_PATH = $(KEYBOARD_PATH_1)
  60. BOARD_MK += $(KEYBOARD_PATH_1)/boards/$(BOARD)/board.mk
  61. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/board/board.mk)","")
  62. BOARD_PATH = $(TOP_DIR)/platforms/chibios/boards/$(BOARD)
  63. BOARD_MK += $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/board/board.mk
  64. KEYBOARD_PATHS += $(BOARD_PATH)/configs
  65. ifneq ("$(wildcard $(BOARD_PATH)/rules.mk)","")
  66. include $(BOARD_PATH)/rules.mk
  67. endif
  68. endif
  69. ifeq ("$(wildcard $(BOARD_MK))","")
  70. BOARD_MK = $(CHIBIOS)/os/hal/boards/$(BOARD)/board.mk
  71. ifeq ("$(wildcard $(BOARD_MK))","")
  72. BOARD_MK = $(CHIBIOS_CONTRIB)/os/hal/boards/$(BOARD)/board.mk
  73. endif
  74. endif
  75. # Bootloader address
  76. ifdef STM32_BOOTLOADER_ADDRESS
  77. OPT_DEFS += -DSTM32_BOOTLOADER_ADDRESS=$(STM32_BOOTLOADER_ADDRESS)
  78. endif
  79. # Work out if we need to set up the include for the bootloader definitions
  80. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/bootloader_defs.h)","")
  81. OPT_DEFS += -include $(KEYBOARD_PATH_5)/bootloader_defs.h
  82. else ifneq ("$(wildcard $(KEYBOARD_PATH_5)/boards/$(BOARD)/bootloader_defs.h)","")
  83. OPT_DEFS += -include $(KEYBOARD_PATH_5)/boards/$(BOARD)/bootloader_defs.h
  84. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/bootloader_defs.h)","")
  85. OPT_DEFS += -include $(KEYBOARD_PATH_4)/bootloader_defs.h
  86. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/boards/$(BOARD)/bootloader_defs.h)","")
  87. OPT_DEFS += -include $(KEYBOARD_PATH_4)/boards/$(BOARD)/bootloader_defs.h
  88. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/bootloader_defs.h)","")
  89. OPT_DEFS += -include $(KEYBOARD_PATH_3)/bootloader_defs.h
  90. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/boards/$(BOARD)/bootloader_defs.h)","")
  91. OPT_DEFS += -include $(KEYBOARD_PATH_3)/boards/$(BOARD)/bootloader_defs.h
  92. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/bootloader_defs.h)","")
  93. OPT_DEFS += -include $(KEYBOARD_PATH_2)/bootloader_defs.h
  94. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/boards/$(BOARD)/bootloader_defs.h)","")
  95. OPT_DEFS += -include $(KEYBOARD_PATH_2)/boards/$(BOARD)/bootloader_defs.h
  96. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/bootloader_defs.h)","")
  97. OPT_DEFS += -include $(KEYBOARD_PATH_1)/bootloader_defs.h
  98. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/boards/$(BOARD)/bootloader_defs.h)","")
  99. OPT_DEFS += -include $(KEYBOARD_PATH_1)/boards/$(BOARD)/bootloader_defs.h
  100. else ifneq ("$(wildcard $(BOARD_PATH)/configs/bootloader_defs.h)","")
  101. OPT_DEFS += -include $(BOARD_PATH)/configs/bootloader_defs.h
  102. endif
  103. # Work out the config file directories
  104. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/chconf.h)","")
  105. CHCONFDIR = $(KEYBOARD_PATH_5)
  106. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/chconf.h)","")
  107. CHCONFDIR = $(KEYBOARD_PATH_4)
  108. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/chconf.h)","")
  109. CHCONFDIR = $(KEYBOARD_PATH_3)
  110. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/chconf.h)","")
  111. CHCONFDIR = $(KEYBOARD_PATH_2)
  112. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/chconf.h)","")
  113. CHCONFDIR = $(KEYBOARD_PATH_1)
  114. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs/chconf.h)","")
  115. CHCONFDIR = $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs
  116. else ifneq ("$(wildcard $(TOP_DIR)/platforms/boards/chibios/common/configs/chconf.h)","")
  117. CHCONFDIR = $(TOP_DIR)/platforms/chibios/boards/common/configs
  118. endif
  119. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/halconf.h)","")
  120. HALCONFDIR = $(KEYBOARD_PATH_5)
  121. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/halconf.h)","")
  122. HALCONFDIR = $(KEYBOARD_PATH_4)
  123. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/halconf.h)","")
  124. HALCONFDIR = $(KEYBOARD_PATH_3)
  125. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/halconf.h)","")
  126. HALCONFDIR = $(KEYBOARD_PATH_2)
  127. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/halconf.h)","")
  128. HALCONFDIR = $(KEYBOARD_PATH_1)
  129. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs/halconf.h)","")
  130. HALCONFDIR = $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs
  131. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/common/configs/halconf.h)","")
  132. HALCONFDIR = $(TOP_DIR)/platforms/chibios/boards/common/configs
  133. endif
  134. # HAL-OSAL files (optional).
  135. include $(CHIBIOS)/os/hal/hal.mk
  136. ifeq ("$(PLATFORM_NAME)","")
  137. PLATFORM_NAME = platform
  138. endif
  139. PLATFORM_MK = $(CHIBIOS)/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES)/$(PLATFORM_NAME).mk
  140. ifeq ("$(wildcard $(PLATFORM_MK))","")
  141. PLATFORM_MK = $(CHIBIOS_CONTRIB)/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES)/$(PLATFORM_NAME).mk
  142. endif
  143. include $(PLATFORM_MK)
  144. include $(BOARD_MK)
  145. -include $(CHIBIOS)/os/hal/osal/rt/osal.mk # ChibiOS <= 19.x
  146. -include $(CHIBIOS)/os/hal/osal/rt-nil/osal.mk # ChibiOS >= 20.x
  147. # RTOS files (optional).
  148. include $(CHIBIOS)/os/rt/rt.mk
  149. # Compability with old version
  150. PORT_V = $(CHIBIOS)/os/rt/ports/ARMCMx/compilers/GCC/mk/port_v$(ARMV)m.mk
  151. ifeq ("$(wildcard $(PORT_V))","")
  152. PORT_V = $(CHIBIOS)/os/common/ports/ARMCMx/compilers/GCC/mk/port_v$(ARMV)m.mk
  153. endif
  154. include $(PORT_V)
  155. # Other files (optional).
  156. include $(CHIBIOS)/os/hal/lib/streams/streams.mk
  157. RULESPATH = $(CHIBIOS)/os/common/ports/ARMCMx/compilers/GCC
  158. ifeq ("$(wildcard $(RULESPATH)/rules.mk)","")
  159. RULESPATH = $(CHIBIOS)/os/common/startup/ARMCMx/compilers/GCC
  160. endif
  161. # Define linker script file here
  162. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/ld/$(MCU_LDSCRIPT).ld)","")
  163. LDSCRIPT = $(KEYBOARD_PATH_5)/ld/$(MCU_LDSCRIPT).ld
  164. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/ld/$(MCU_LDSCRIPT).ld)","")
  165. LDSCRIPT = $(KEYBOARD_PATH_4)/ld/$(MCU_LDSCRIPT).ld
  166. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/ld/$(MCU_LDSCRIPT).ld)","")
  167. LDSCRIPT = $(KEYBOARD_PATH_3)/ld/$(MCU_LDSCRIPT).ld
  168. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/ld/$(MCU_LDSCRIPT).ld)","")
  169. LDSCRIPT = $(KEYBOARD_PATH_2)/ld/$(MCU_LDSCRIPT).ld
  170. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/ld/$(MCU_LDSCRIPT).ld)","")
  171. LDSCRIPT = $(KEYBOARD_PATH_1)/ld/$(MCU_LDSCRIPT).ld
  172. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/ld/$(MCU_LDSCRIPT).ld)","")
  173. LDFLAGS += -L$(TOP_DIR)/platforms/chibios/boards/$(BOARD)/ld
  174. LDSCRIPT = $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/ld/$(MCU_LDSCRIPT).ld
  175. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/common/ld/$(MCU_LDSCRIPT).ld)","")
  176. LDSCRIPT = $(TOP_DIR)/platforms/chibios/boards/common/ld/$(MCU_LDSCRIPT).ld
  177. else ifneq ("$(wildcard $(STARTUPLD_CONTRIB)/$(MCU_LDSCRIPT).ld)","")
  178. LDSCRIPT = $(STARTUPLD_CONTRIB)/$(MCU_LDSCRIPT).ld
  179. USE_CHIBIOS_CONTRIB = yes
  180. else
  181. LDSCRIPT = $(STARTUPLD)/$(MCU_LDSCRIPT).ld
  182. endif
  183. CHIBISRC = $(STARTUPSRC) \
  184. $(KERNSRC) \
  185. $(PORTSRC) \
  186. $(OSALSRC) \
  187. $(HALSRC) \
  188. $(PLATFORMSRC) \
  189. $(BOARDSRC) \
  190. $(STREAMSSRC) \
  191. $(CHIBIOS)/os/various/syscalls.c \
  192. $(PLATFORM_COMMON_DIR)/syscall-fallbacks.c \
  193. $(PLATFORM_COMMON_DIR)/wait.c
  194. # Ensure the ASM files are not subjected to LTO -- it'll strip out interrupt handlers otherwise.
  195. QUANTUM_LIB_SRC += $(STARTUPASM) $(PORTASM) $(OSALASM) $(PLATFORMASM)
  196. CHIBISRC := $(patsubst $(TOP_DIR)/%,%,$(CHIBISRC))
  197. EXTRAINCDIRS += $(CHIBIOS)/os/license $(CHIBIOS)/os/oslib/include \
  198. $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs \
  199. $(TOP_DIR)/platforms/chibios/boards/common/configs \
  200. $(HALCONFDIR) $(CHCONFDIR) \
  201. $(STARTUPINC) $(KERNINC) $(PORTINC) $(OSALINC) \
  202. $(HALINC) $(PLATFORMINC) $(BOARDINC) $(TESTINC) \
  203. $(STREAMSINC) $(CHIBIOS)/os/various $(COMMON_VPATH)
  204. #
  205. # ChibiOS-Contrib
  206. ##############################################################################
  207. # Work out if we're using ChibiOS-Contrib by checking if halconf_community.h exists
  208. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/halconf_community.h)","")
  209. USE_CHIBIOS_CONTRIB = yes
  210. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/halconf_community.h)","")
  211. USE_CHIBIOS_CONTRIB = yes
  212. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/halconf_community.h)","")
  213. USE_CHIBIOS_CONTRIB = yes
  214. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/halconf_community.h)","")
  215. USE_CHIBIOS_CONTRIB = yes
  216. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/halconf_community.h)","")
  217. USE_CHIBIOS_CONTRIB = yes
  218. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs/halconf_community.h)","")
  219. USE_CHIBIOS_CONTRIB = yes
  220. endif
  221. ifeq ($(strip $(USE_CHIBIOS_CONTRIB)),yes)
  222. include $(CHIBIOS_CONTRIB)/os/hal/hal.mk
  223. CHIBISRC += $(PLATFORMSRC_CONTRIB) $(HALSRC_CONTRIB)
  224. EXTRAINCDIRS += $(PLATFORMINC_CONTRIB) $(HALINC_CONTRIB) $(CHIBIOS_CONTRIB)/os/various
  225. endif
  226. #
  227. # Project, sources and paths
  228. ##############################################################################
  229. ##############################################################################
  230. # Injected configs
  231. #
  232. ifneq ("$(wildcard $(BOARD_PATH)/configs/config.h)","")
  233. CONFIG_H += $(BOARD_PATH)/configs/config.h
  234. endif
  235. ifneq ("$(wildcard $(BOARD_PATH)/configs/post_config.h)","")
  236. POST_CONFIG_H += $(BOARD_PATH)/configs/post_config.h
  237. endif
  238. ##############################################################################
  239. # Compiler settings
  240. #
  241. CC = arm-none-eabi-gcc
  242. OBJCOPY = arm-none-eabi-objcopy
  243. OBJDUMP = arm-none-eabi-objdump
  244. SIZE = arm-none-eabi-size
  245. AR = arm-none-eabi-ar
  246. NM = arm-none-eabi-nm
  247. HEX = $(OBJCOPY) -O $(FORMAT)
  248. EEP =
  249. BIN = $(OBJCOPY) -O binary
  250. THUMBFLAGS = -DTHUMB_PRESENT -mno-thumb-interwork -DTHUMB_NO_INTERWORKING -mthumb -DTHUMB
  251. COMPILEFLAGS += -fomit-frame-pointer
  252. COMPILEFLAGS += -falign-functions=16
  253. COMPILEFLAGS += -ffunction-sections
  254. COMPILEFLAGS += -fdata-sections
  255. COMPILEFLAGS += -fno-common
  256. COMPILEFLAGS += -fshort-wchar
  257. COMPILEFLAGS += $(THUMBFLAGS)
  258. # FPU options default (Cortex-M4 and Cortex-M7 single precision).
  259. USE_FPU_OPT ?= -mfloat-abi=hard -mfpu=fpv4-sp-d16 -fsingle-precision-constant
  260. # FPU-related options
  261. USE_FPU ?= no
  262. ifneq ($(USE_FPU),no)
  263. COMPILEFLAGS += $(USE_FPU_OPT)
  264. OPT_DEFS += -DCORTEX_USE_FPU=TRUE
  265. else
  266. OPT_DEFS += -DCORTEX_USE_FPU=FALSE
  267. endif
  268. CFLAGS += $(COMPILEFLAGS)
  269. ASFLAGS += $(THUMBFLAGS)
  270. CXXFLAGS += $(COMPILEFLAGS)
  271. CXXFLAGS += -fno-rtti
  272. LDFLAGS +=-Wl,--gc-sections
  273. LDFLAGS +=-Wl,--no-wchar-size-warning
  274. LDFLAGS += -mno-thumb-interwork -mthumb
  275. LDSYMBOLS =,--defsym=__process_stack_size__=$(USE_PROCESS_STACKSIZE)
  276. LDSYMBOLS :=$(LDSYMBOLS),--defsym=__main_stack_size__=$(USE_EXCEPTIONS_STACKSIZE)
  277. LDFLAGS += -Wl,--script=$(LDSCRIPT)$(LDSYMBOLS)
  278. LDFLAGS += --specs=nano.specs
  279. OPT_DEFS += -DPROTOCOL_CHIBIOS
  280. # Workaround to stop ChibiOS from complaining about new GCC -- it's been fixed for 7/8/9 already
  281. OPT_DEFS += -DPORT_IGNORE_GCC_VERSION_CHECK=1
  282. MCUFLAGS = -mcpu=$(MCU)
  283. DEBUG = gdb
  284. # List any extra directories to look for libraries here.
  285. EXTRALIBDIRS = $(RULESPATH)/ld
  286. bin: $(BUILD_DIR)/$(TARGET).bin sizeafter
  287. $(COPY) $(BUILD_DIR)/$(TARGET).bin $(TARGET).bin;