logo

qmk_firmware

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

platform.mk (21074B)


  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. #
  26. # Startup, Port and Platform support selection
  27. ##############################################################################
  28. ifeq ($(strip $(MCU)), risc-v)
  29. # RISC-V Support
  30. # As of 7.4.2021 there is only one supported RISC-V platform in Chibios-Contrib,
  31. # therefore all required settings are hard-coded
  32. USE_CHIBIOS_CONTRIB = yes
  33. STARTUP_MK = $(CHIBIOS_CONTRIB)/os/common/startup/RISCV-ECLIC/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  34. PORT_V = $(CHIBIOS_CONTRIB)/os/common/ports/RISCV-ECLIC/compilers/GCC/mk/port.mk
  35. RULESPATH = $(CHIBIOS_CONTRIB)/os/common/startup/RISCV-ECLIC/compilers/GCC
  36. else
  37. # ARM Support
  38. CHIBIOS_PORT ?=
  39. ifeq ("$(CHIBIOS_PORT)","")
  40. CHIBIOS_PORT = ARMv$(ARMV)-M
  41. endif
  42. # Startup files. Try a few different locations, for compability with old versions and
  43. # for things hardware in the contrib repository
  44. STARTUP_MK = $(CHIBIOS)/os/common/ports/ARMCMx/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  45. ifeq ("$(wildcard $(STARTUP_MK))","")
  46. STARTUP_MK = $(CHIBIOS)/os/common/startup/ARMCMx/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  47. ifeq ("$(wildcard $(STARTUP_MK))","")
  48. STARTUP_MK = $(CHIBIOS_CONTRIB)/os/common/startup/ARMCMx/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  49. endif
  50. endif
  51. # Port files. Try a few different locations, for compability with old versions and
  52. # for things hardware in the contrib repository
  53. PORT_V = $(CHIBIOS)/os/common/ports/$(CHIBIOS_PORT)/compilers/GCC/mk/port.mk
  54. ifeq ("$(wildcard $(PORT_V))","")
  55. PORT_V = $(CHIBIOS)/os/rt/ports/ARMCMx/compilers/GCC/mk/port_v$(ARMV)m.mk
  56. ifeq ("$(wildcard $(PORT_V))","")
  57. PORT_V = $(CHIBIOS)/os/common/ports/ARMCMx/compilers/GCC/mk/port_v$(ARMV)m.mk
  58. endif
  59. endif
  60. # Rules location. Try a few different locations, for compability with old versions and
  61. # for things hardware in the contrib repository
  62. RULESPATH = $(CHIBIOS)/os/common/ports/$(CHIBIOS_PORT)/compilers/GCC
  63. ifeq ("$(wildcard $(RULESPATH)/rules.mk)","")
  64. RULESPATH = $(CHIBIOS)/os/common/ports/ARMCMx/compilers/GCC
  65. ifeq ("$(wildcard $(RULESPATH)/rules.mk)","")
  66. RULESPATH = $(CHIBIOS)/os/common/startup/ARMCMx/compilers/GCC
  67. endif
  68. endif
  69. endif
  70. ifeq ("$(PLATFORM_NAME)","")
  71. PLATFORM_NAME = platform
  72. endif
  73. # If no MCU port name was specified, use the family instead
  74. ifeq ("$(MCU_PORT_NAME)","")
  75. MCU_PORT_NAME = $(MCU_FAMILY)
  76. endif
  77. ifeq ("$(wildcard $(PLATFORM_MK))","")
  78. PLATFORM_MK = $(CHIBIOS_CONTRIB)/os/hal/ports/$(MCU_PORT_NAME)/$(MCU_SERIES)/$(PLATFORM_NAME).mk
  79. ifeq ("$(wildcard $(PLATFORM_MK))","")
  80. PLATFORM_MK = $(CHIBIOS)/os/hal/ports/$(MCU_PORT_NAME)/$(MCU_SERIES)/$(PLATFORM_NAME).mk
  81. endif
  82. endif
  83. # If no MCU architecture specified, use the MCU instead (allows for mcu_selection.mk to swap to cortex-m0 etc.)
  84. ifeq ("$(MCU_ARCH)","")
  85. MCU_ARCH = $(MCU)
  86. endif
  87. include $(STARTUP_MK)
  88. include $(PORT_V)
  89. include $(PLATFORM_MK)
  90. #
  91. # Board support selection.
  92. ##############################################################################
  93. BOARD_MK :=
  94. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/boards/$(BOARD)/board.mk)","")
  95. BOARD_PATH = $(KEYBOARD_PATH_5)
  96. BOARD_MK += $(KEYBOARD_PATH_5)/boards/$(BOARD)/board.mk
  97. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/boards/$(BOARD)/board.mk)","")
  98. BOARD_PATH = $(KEYBOARD_PATH_4)
  99. BOARD_MK += $(KEYBOARD_PATH_4)/boards/$(BOARD)/board.mk
  100. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/boards/$(BOARD)/board.mk)","")
  101. BOARD_PATH = $(KEYBOARD_PATH_3)
  102. BOARD_MK += $(KEYBOARD_PATH_3)/boards/$(BOARD)/board.mk
  103. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/boards/$(BOARD)/board.mk)","")
  104. BOARD_PATH = $(KEYBOARD_PATH_2)
  105. BOARD_MK += $(KEYBOARD_PATH_2)/boards/$(BOARD)/board.mk
  106. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/boards/$(BOARD)/board.mk)","")
  107. BOARD_PATH = $(KEYBOARD_PATH_1)
  108. BOARD_MK += $(KEYBOARD_PATH_1)/boards/$(BOARD)/board.mk
  109. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/board/board.mk)","")
  110. BOARD_PATH = $(TOP_DIR)/platforms/chibios/boards/$(BOARD)
  111. BOARD_MK += $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/board/board.mk
  112. KEYBOARD_PATHS += $(BOARD_PATH)/configs
  113. ifneq ("$(wildcard $(BOARD_PATH)/rules.mk)","")
  114. include $(BOARD_PATH)/rules.mk
  115. endif
  116. endif
  117. ifeq ("$(wildcard $(BOARD_MK))","")
  118. BOARD_MK = $(CHIBIOS)/os/hal/boards/$(BOARD)/board.mk
  119. ifeq ("$(wildcard $(BOARD_MK))","")
  120. BOARD_MK = $(CHIBIOS_CONTRIB)/os/hal/boards/$(BOARD)/board.mk
  121. endif
  122. endif
  123. include $(BOARD_MK)
  124. #
  125. # Bootloader selection.
  126. ##############################################################################
  127. # Set bootloader address if supplied.
  128. ifdef STM32_BOOTLOADER_ADDRESS
  129. OPT_DEFS += -DSTM32_BOOTLOADER_ADDRESS=$(STM32_BOOTLOADER_ADDRESS)
  130. endif
  131. ifdef WB32_BOOTLOADER_ADDRESS
  132. OPT_DEFS += -DWB32_BOOTLOADER_ADDRESS=$(WB32_BOOTLOADER_ADDRESS)
  133. endif
  134. ifdef AT32_BOOTLOADER_ADDRESS
  135. OPT_DEFS += -DAT32_BOOTLOADER_ADDRESS=$(AT32_BOOTLOADER_ADDRESS)
  136. endif
  137. # Work out if we need to set up the include for the bootloader definitions
  138. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/bootloader_defs.h)","")
  139. OPT_DEFS += -include $(KEYBOARD_PATH_5)/bootloader_defs.h
  140. else ifneq ("$(wildcard $(KEYBOARD_PATH_5)/boards/$(BOARD)/bootloader_defs.h)","")
  141. OPT_DEFS += -include $(KEYBOARD_PATH_5)/boards/$(BOARD)/bootloader_defs.h
  142. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/bootloader_defs.h)","")
  143. OPT_DEFS += -include $(KEYBOARD_PATH_4)/bootloader_defs.h
  144. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/boards/$(BOARD)/bootloader_defs.h)","")
  145. OPT_DEFS += -include $(KEYBOARD_PATH_4)/boards/$(BOARD)/bootloader_defs.h
  146. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/bootloader_defs.h)","")
  147. OPT_DEFS += -include $(KEYBOARD_PATH_3)/bootloader_defs.h
  148. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/boards/$(BOARD)/bootloader_defs.h)","")
  149. OPT_DEFS += -include $(KEYBOARD_PATH_3)/boards/$(BOARD)/bootloader_defs.h
  150. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/bootloader_defs.h)","")
  151. OPT_DEFS += -include $(KEYBOARD_PATH_2)/bootloader_defs.h
  152. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/boards/$(BOARD)/bootloader_defs.h)","")
  153. OPT_DEFS += -include $(KEYBOARD_PATH_2)/boards/$(BOARD)/bootloader_defs.h
  154. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/bootloader_defs.h)","")
  155. OPT_DEFS += -include $(KEYBOARD_PATH_1)/bootloader_defs.h
  156. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/boards/$(BOARD)/bootloader_defs.h)","")
  157. OPT_DEFS += -include $(KEYBOARD_PATH_1)/boards/$(BOARD)/bootloader_defs.h
  158. else ifneq ("$(wildcard $(BOARD_PATH)/configs/bootloader_defs.h)","")
  159. OPT_DEFS += -include $(BOARD_PATH)/configs/bootloader_defs.h
  160. endif
  161. #
  162. # ChibiOS config selection.
  163. ##############################################################################
  164. # Work out the config file directories
  165. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/chconf.h)","")
  166. CHCONFDIR = $(KEYBOARD_PATH_5)
  167. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/chconf.h)","")
  168. CHCONFDIR = $(KEYBOARD_PATH_4)
  169. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/chconf.h)","")
  170. CHCONFDIR = $(KEYBOARD_PATH_3)
  171. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/chconf.h)","")
  172. CHCONFDIR = $(KEYBOARD_PATH_2)
  173. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/chconf.h)","")
  174. CHCONFDIR = $(KEYBOARD_PATH_1)
  175. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs/chconf.h)","")
  176. CHCONFDIR = $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs
  177. else ifneq ("$(wildcard $(TOP_DIR)/platforms/boards/chibios/common/configs/chconf.h)","")
  178. CHCONFDIR = $(TOP_DIR)/platforms/chibios/boards/common/configs
  179. endif
  180. #
  181. # HAL config selection.
  182. ##############################################################################
  183. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/halconf.h)","")
  184. HALCONFDIR = $(KEYBOARD_PATH_5)
  185. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/halconf.h)","")
  186. HALCONFDIR = $(KEYBOARD_PATH_4)
  187. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/halconf.h)","")
  188. HALCONFDIR = $(KEYBOARD_PATH_3)
  189. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/halconf.h)","")
  190. HALCONFDIR = $(KEYBOARD_PATH_2)
  191. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/halconf.h)","")
  192. HALCONFDIR = $(KEYBOARD_PATH_1)
  193. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs/halconf.h)","")
  194. HALCONFDIR = $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs
  195. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/common/configs/halconf.h)","")
  196. HALCONFDIR = $(TOP_DIR)/platforms/chibios/boards/common/configs
  197. endif
  198. #
  199. # Linker script selection.
  200. ##############################################################################
  201. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/ld/$(MCU_LDSCRIPT).ld)","")
  202. LDSCRIPT = $(KEYBOARD_PATH_5)/ld/$(MCU_LDSCRIPT).ld
  203. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/ld/$(MCU_LDSCRIPT).ld)","")
  204. LDSCRIPT = $(KEYBOARD_PATH_4)/ld/$(MCU_LDSCRIPT).ld
  205. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/ld/$(MCU_LDSCRIPT).ld)","")
  206. LDSCRIPT = $(KEYBOARD_PATH_3)/ld/$(MCU_LDSCRIPT).ld
  207. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/ld/$(MCU_LDSCRIPT).ld)","")
  208. LDSCRIPT = $(KEYBOARD_PATH_2)/ld/$(MCU_LDSCRIPT).ld
  209. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/ld/$(MCU_LDSCRIPT).ld)","")
  210. LDSCRIPT = $(KEYBOARD_PATH_1)/ld/$(MCU_LDSCRIPT).ld
  211. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/ld/$(MCU_LDSCRIPT)_$(BOOTLOADER).ld)","")
  212. LDFLAGS += -L$(TOP_DIR)/platforms/chibios/boards/$(BOARD)/ld
  213. LDSCRIPT = $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/ld/$(MCU_LDSCRIPT)_$(BOOTLOADER).ld
  214. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/common/ld/$(MCU_LDSCRIPT)_$(BOOTLOADER).ld)","")
  215. LDSCRIPT = $(TOP_DIR)/platforms/chibios/boards/common/ld/$(MCU_LDSCRIPT)_$(BOOTLOADER).ld
  216. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/ld/$(MCU_LDSCRIPT).ld)","")
  217. LDFLAGS += -L$(TOP_DIR)/platforms/chibios/boards/$(BOARD)/ld
  218. LDSCRIPT = $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/ld/$(MCU_LDSCRIPT).ld
  219. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/common/ld/$(MCU_LDSCRIPT).ld)","")
  220. LDSCRIPT = $(TOP_DIR)/platforms/chibios/boards/common/ld/$(MCU_LDSCRIPT).ld
  221. else ifneq ("$(wildcard $(STARTUPLD_CONTRIB)/$(MCU_LDSCRIPT).ld)","")
  222. LDSCRIPT = $(STARTUPLD_CONTRIB)/$(MCU_LDSCRIPT).ld
  223. USE_CHIBIOS_CONTRIB = yes
  224. else
  225. LDSCRIPT = $(STARTUPLD)/$(MCU_LDSCRIPT).ld
  226. endif
  227. #
  228. # Include ChibiOS makefiles.
  229. ##############################################################################
  230. # HAL-OSAL files (optional).
  231. include $(CHIBIOS)/os/hal/hal.mk
  232. include $(CHIBIOS)/os/oslib/oslib.mk
  233. include $(CHIBIOS)/os/hal/osal/rt-nil/osal.mk
  234. # RTOS files (optional).
  235. include $(CHIBIOS)/os/rt/rt.mk
  236. # Other files (optional).
  237. include $(CHIBIOS)/os/hal/lib/streams/streams.mk
  238. PLATFORM_SRC = \
  239. $(STARTUPSRC) \
  240. $(KERNSRC) \
  241. $(PORTSRC) \
  242. $(OSALSRC) \
  243. $(OSLIBSRC) \
  244. $(HALSRC) \
  245. $(PLATFORMSRC) \
  246. $(BOARDSRC) \
  247. $(STREAMSSRC) \
  248. $(CHIBIOS)/os/various/syscalls.c \
  249. $(PLATFORM_COMMON_DIR)/syscall-fallbacks.c \
  250. $(PLATFORM_COMMON_DIR)/wait.c \
  251. $(PLATFORM_COMMON_DIR)/synchronization_util.c \
  252. $(PLATFORM_COMMON_DIR)/interrupt_handlers.c
  253. # Ensure the ASM files are not subjected to LTO -- it'll strip out interrupt handlers otherwise.
  254. QUANTUM_LIB_SRC += $(STARTUPASM) $(PORTASM) $(OSALASM) $(PLATFORMASM)
  255. PLATFORM_SRC := $(patsubst $(TOP_DIR)/%,%,$(PLATFORM_SRC))
  256. EXTRAINCDIRS += $(CHIBIOS)/os/license \
  257. $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs \
  258. $(TOP_DIR)/platforms/chibios/boards/common/configs \
  259. $(HALCONFDIR) $(CHCONFDIR) \
  260. $(STARTUPINC) $(KERNINC) $(PORTINC) $(OSALINC) $(OSLIBINC) \
  261. $(HALINC) $(PLATFORMINC) $(BOARDINC) $(TESTINC) \
  262. $(STREAMSINC) $(CHIBIOS)/os/various $(COMMON_VPATH)
  263. #
  264. # QMK specific MCU family support selection.
  265. ##############################################################################
  266. ifneq ("$(wildcard $(PLATFORM_PATH)/$(PLATFORM_KEY)/vendors/$(MCU_FAMILY)/$(MCU_SERIES).mk)","")
  267. # Either by MCU series e.g. STM32/STM32F1xx.mk or...
  268. include $(PLATFORM_PATH)/$(PLATFORM_KEY)/vendors/$(MCU_FAMILY)/$(MCU_SERIES).mk
  269. else ifneq ("$(wildcard $(PLATFORM_PATH)/$(PLATFORM_KEY)/vendors/$(MCU_FAMILY)/$(MCU_FAMILY).mk)","")
  270. # By MCU family e.g. STM32/STM32.mk
  271. include $(PLATFORM_PATH)/$(PLATFORM_KEY)/vendors/$(MCU_FAMILY)/$(MCU_FAMILY).mk
  272. endif
  273. #
  274. # ChibiOS-Contrib
  275. ##############################################################################
  276. # Work out if we're using ChibiOS-Contrib by checking if halconf_community.h exists
  277. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/halconf_community.h)","")
  278. USE_CHIBIOS_CONTRIB = yes
  279. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/halconf_community.h)","")
  280. USE_CHIBIOS_CONTRIB = yes
  281. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/halconf_community.h)","")
  282. USE_CHIBIOS_CONTRIB = yes
  283. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/halconf_community.h)","")
  284. USE_CHIBIOS_CONTRIB = yes
  285. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/halconf_community.h)","")
  286. USE_CHIBIOS_CONTRIB = yes
  287. else ifneq ("$(wildcard $(TOP_DIR)/platforms/chibios/boards/$(BOARD)/configs/halconf_community.h)","")
  288. USE_CHIBIOS_CONTRIB = yes
  289. endif
  290. ifeq ($(strip $(USE_CHIBIOS_CONTRIB)),yes)
  291. include $(CHIBIOS_CONTRIB)/os/hal/hal.mk
  292. PLATFORM_SRC += $(PLATFORMSRC_CONTRIB) $(HALSRC_CONTRIB)
  293. EXTRAINCDIRS += $(PLATFORMINC_CONTRIB) $(HALINC_CONTRIB) $(CHIBIOS_CONTRIB)/os/various
  294. endif
  295. #
  296. # Project, sources and paths
  297. ##############################################################################
  298. ##############################################################################
  299. # Injected configs
  300. #
  301. ifneq ("$(wildcard $(BOARD_PATH)/configs/config.h)","")
  302. CONFIG_H += $(BOARD_PATH)/configs/config.h
  303. endif
  304. ifneq ("$(wildcard $(BOARD_PATH)/configs/post_config.h)","")
  305. POST_CONFIG_H += $(BOARD_PATH)/configs/post_config.h
  306. endif
  307. ##############################################################################
  308. # Compiler and Linker configuration
  309. #
  310. # Use defined stack sizes of the main thread in linker scripts
  311. SHARED_LDSYMBOLS = -Wl,--defsym=__process_stack_size__=$(USE_PROCESS_STACKSIZE),--defsym=__main_stack_size__=$(USE_EXCEPTIONS_STACKSIZE)
  312. # Shared Compiler flags for all toolchains
  313. SHARED_CFLAGS = -fomit-frame-pointer \
  314. -ffunction-sections \
  315. -fdata-sections \
  316. -fno-common \
  317. -fshort-wchar \
  318. -fno-builtin-printf
  319. LDSCRIPT_PATH := $(shell dirname "$(LDSCRIPT)")
  320. # Shared Linker flags for all toolchains
  321. SHARED_LDFLAGS = -T $(LDSCRIPT) \
  322. -L $(LDSCRIPT_PATH) \
  323. -Wl,--gc-sections \
  324. -nostartfiles
  325. ifeq ($(strip $(MCU)), risc-v)
  326. # RISC-V toolchain specific configuration
  327. # Find suitable GCC compiler
  328. ifeq ($(strip $(TOOLCHAIN)),)
  329. ifneq ($(shell which riscv32-unknown-elf-gcc 2>/dev/null),)
  330. TOOLCHAIN = riscv32-unknown-elf-
  331. else
  332. ifneq ($(shell which riscv64-unknown-elf-gcc 2>/dev/null),)
  333. TOOLCHAIN = riscv64-unknown-elf-
  334. else
  335. $(call CATASTROPHIC_ERROR,Missing toolchain,No RISC-V toolchain found. Can't find riscv32-unknown-elf-gcc or riscv64-unknown-elf-gcc found in your systems PATH variable. Please install a valid toolchain and make it accessible!)
  336. endif
  337. endif
  338. endif
  339. # Default to compiling with picolibc for RISC-V targets if available, which
  340. # is available by default on distributions based on Debian 11+.
  341. ifeq ($(shell $(TOOLCHAIN)gcc --specs=picolibc.specs -E - 2>/dev/null >/dev/null </dev/null ; echo $$?),0)
  342. # Toolchain specific Compiler flags Note that we still link with our own
  343. # linker script by providing it via the -T flag in SHARED_LDFLAGS.
  344. TOOLCHAIN_CFLAGS = --specs=picolibc.specs
  345. # picolibc internally uses __heap_start and __heap_end instead of the
  346. # defacto chibios linker script standard __heap_base__ and __heap_end__
  347. # therefore we introduce these symbols as an alias.
  348. TOOLCHAIN_LDSYMBOLS = -Wl,--defsym=__heap_start=__heap_base__,--defsym=__heap_end=__heap_end__
  349. # Tell QMK that we are compiling with picolibc.
  350. OPT_DEFS += -DUSE_PICOLIBC
  351. endif
  352. # MCU architecture flags
  353. MCUFLAGS = -march=$(MCU_ARCH) \
  354. -mabi=$(MCU_ABI) \
  355. -mcmodel=$(MCU_CMODEL) \
  356. -mstrict-align
  357. # Deal with different arch revisions and gcc renaming them
  358. ifneq ($(shell echo 'int main() { asm("csrc 0x300,8"); return 0; }' | $(TOOLCHAIN)gcc $(MCUFLAGS) $(TOOLCHAIN_CFLAGS) -x c -o /dev/null - 2>/dev/null >/dev/null; echo $$?),0)
  359. MCUFLAGS = -march=$(MCU_ARCH)_zicsr \
  360. -mabi=$(MCU_ABI) \
  361. -mcmodel=$(MCU_CMODEL) \
  362. -mstrict-align
  363. ifneq ($(shell echo 'int main() { asm("csrc 0x300,8"); return 0; }' | $(TOOLCHAIN)gcc $(MCUFLAGS) $(TOOLCHAIN_CFLAGS) -x c -o /dev/null - 2>/dev/null >/dev/null; echo $$?),0)
  364. $(call CATASTROPHIC_ERROR,Incompatible toolchain,No compatible RISC-V toolchain found. Can't work out correct architecture.)
  365. endif
  366. endif
  367. else
  368. # ARM toolchain specific configuration
  369. TOOLCHAIN ?= arm-none-eabi-
  370. # Toolchain specific Linker flags
  371. TOOLCHAIN_LDFLAGS = -Wl,--no-wchar-size-warning \
  372. --specs=nano.specs
  373. # MCU architecture flags
  374. MCUFLAGS = -mcpu=$(MCU) \
  375. -mthumb -DTHUMB_PRESENT \
  376. -mno-thumb-interwork -DTHUMB_NO_INTERWORKING \
  377. -mno-unaligned-access
  378. # Some ARM cores like the M4 and M7 have floating point units which can be enabled
  379. USE_FPU ?= no
  380. ifneq ($(USE_FPU),no)
  381. OPT_DEFS += -DCORTEX_USE_FPU=TRUE
  382. # Default is single precision floats
  383. USE_FPU_OPT ?= -mfloat-abi=hard \
  384. -mfpu=fpv4-sp-d16 \
  385. -fsingle-precision-constant
  386. MCUFLAGS += $(USE_FPU_OPT)
  387. else
  388. OPT_DEFS += -DCORTEX_USE_FPU=FALSE
  389. endif
  390. endif
  391. # Extra config.h files for the platform
  392. ifneq ("$(wildcard $(PLATFORM_COMMON_DIR)/vendors/$(MCU_FAMILY)/$(MCU_SERIES)/config.h)","")
  393. CONFIG_H += $(PLATFORM_COMMON_DIR)/vendors/$(MCU_FAMILY)/$(MCU_SERIES)/config.h
  394. endif
  395. ifneq ("$(wildcard $(PLATFORM_COMMON_DIR)/vendors/$(MCU_FAMILY)/config.h)","")
  396. CONFIG_H += $(PLATFORM_COMMON_DIR)/vendors/$(MCU_FAMILY)/config.h
  397. endif
  398. CONFIG_H += $(PLATFORM_COMMON_DIR)/config.h
  399. # Assembler flags
  400. ASFLAGS += $(SHARED_ASFLAGS) $(TOOLCHAIN_ASFLAGS)
  401. # C Compiler flags
  402. CFLAGS += $(SHARED_CFLAGS) $(TOOLCHAIN_CFLAGS)
  403. # C++ Compiler flags
  404. CXXFLAGS += $(CFLAGS) $(SHARED_CXXFLAGS) $(TOOLCHAIN_CXXFLAGS) -fno-rtti
  405. # Linker flags
  406. LDFLAGS += $(SHARED_LDFLAGS) $(SHARED_LDSYMBOLS) $(TOOLCHAIN_LDFLAGS) $(TOOLCHAIN_LDSYMBOLS) $(MCUFLAGS)
  407. # Tell QMK that we are hosting it on ChibiOS.
  408. OPT_DEFS += -DPROTOCOL_CHIBIOS
  409. # And what flavor of MCU
  410. OPT_DEFS += -DMCU_$(MCU_FAMILY)
  411. # ChibiOS supports synchronization primitives like a Mutex
  412. OPT_DEFS += -DPLATFORM_SUPPORTS_SYNCHRONIZATION
  413. # Workaround to stop ChibiOS from complaining about new GCC -- it's been fixed for 7/8/9 already
  414. OPT_DEFS += -DPORT_IGNORE_GCC_VERSION_CHECK=1
  415. # Construct GCC toolchain
  416. CC = $(CC_PREFIX) $(TOOLCHAIN)gcc
  417. OBJCOPY = $(TOOLCHAIN)objcopy
  418. OBJDUMP = $(TOOLCHAIN)objdump
  419. SIZE = $(TOOLCHAIN)size
  420. AR = $(TOOLCHAIN)ar
  421. NM = $(TOOLCHAIN)nm
  422. HEX = $(OBJCOPY) -O $(FORMAT)
  423. EEP =
  424. BIN = $(OBJCOPY) -O binary
  425. # disable warning about RWX triggered by ChibiOS linker scripts
  426. ifeq ("$(shell echo "int main(){}" | $(CC) -shared -Wl,--no-warn-rwx-segments -x c - -o /dev/null 2>&1)", "")
  427. SHARED_LDFLAGS += -Wl,--no-warn-rwx-segments
  428. endif
  429. ##############################################################################
  430. # Make targets
  431. #
  432. DEBUG = gdb
  433. # List any extra directories to look for libraries here.
  434. EXTRALIBDIRS = $(RULESPATH)/ld
  435. bin: $(BUILD_DIR)/$(TARGET).bin sizeafter
  436. $(COPY) $(BUILD_DIR)/$(TARGET).bin $(TARGET).bin;