chibios.mk 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  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. CHIBIOS = $(TOP_DIR)/lib/chibios
  23. CHIBIOS_CONTRIB = $(TOP_DIR)/lib/chibios-contrib
  24. # Startup files. Try a few different locations, for compability with old versions and
  25. # for things hardware in the contrib repository
  26. STARTUP_MK = $(CHIBIOS)/os/common/ports/ARMCMx/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  27. ifeq ("$(wildcard $(STARTUP_MK))","")
  28. STARTUP_MK = $(CHIBIOS)/os/common/startup/ARMCMx/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  29. ifeq ("$(wildcard $(STARTUP_MK))","")
  30. STARTUP_MK = $(CHIBIOS_CONTRIB)/os/common/startup/ARMCMx/compilers/GCC/mk/startup_$(MCU_STARTUP).mk
  31. endif
  32. endif
  33. include $(STARTUP_MK)
  34. # HAL-OSAL files (optional).
  35. include $(CHIBIOS)/os/hal/hal.mk
  36. PLATFORM_MK = $(CHIBIOS)/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES)/platform.mk
  37. ifeq ("$(wildcard $(PLATFORM_MK))","")
  38. PLATFORM_MK = $(CHIBIOS_CONTRIB)/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES)/platform.mk
  39. endif
  40. include $(PLATFORM_MK)
  41. BOARD_MK :=
  42. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/boards/$(BOARD)/board.mk)","")
  43. BOARD_PATH = $(KEYBOARD_PATH_5)
  44. BOARD_MK += $(KEYBOARD_PATH_5)/boards/$(BOARD)/board.mk
  45. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/boards/$(BOARD)/board.mk)","")
  46. BOARD_PATH = $(KEYBOARD_PATH_4)
  47. BOARD_MK += $(KEYBOARD_PATH_4)/boards/$(BOARD)/board.mk
  48. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/boards/$(BOARD)/board.mk)","")
  49. BOARD_PATH = $(KEYBOARD_PATH_3)
  50. BOARD_MK += $(KEYBOARD_PATH_3)/boards/$(BOARD)/board.mk
  51. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/boards/$(BOARD)/board.mk)","")
  52. BOARD_PATH = $(KEYBOARD_PATH_2)
  53. BOARD_MK += $(KEYBOARD_PATH_2)/boards/$(BOARD)/board.mk
  54. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/boards/$(BOARD)/board.mk)","")
  55. BOARD_PATH = $(KEYBOARD_PATH_1)
  56. BOARD_MK += $(KEYBOARD_PATH_1)/boards/$(BOARD)/board.mk
  57. endif
  58. ifeq ("$(wildcard $(BOARD_MK))","")
  59. BOARD_MK = $(CHIBIOS)/os/hal/boards/$(BOARD)/board.mk
  60. ifeq ("$(wildcard $(BOARD_MK))","")
  61. BOARD_MK = $(CHIBIOS_CONTRIB)/os/hal/boards/$(BOARD)/board.mk
  62. endif
  63. endif
  64. include $(BOARD_MK)
  65. include $(CHIBIOS)/os/hal/osal/rt/osal.mk
  66. # RTOS files (optional).
  67. include $(CHIBIOS)/os/rt/rt.mk
  68. # Compability with old version
  69. PORT_V = $(CHIBIOS)/os/rt/ports/ARMCMx/compilers/GCC/mk/port_v$(ARMV)m.mk
  70. ifeq ("$(wildcard $(PORT_V))","")
  71. PORT_V = $(CHIBIOS)/os/common/ports/ARMCMx/compilers/GCC/mk/port_v$(ARMV)m.mk
  72. endif
  73. include $(PORT_V)
  74. # Other files (optional).
  75. include $(CHIBIOS)/os/hal/lib/streams/streams.mk
  76. RULESPATH = $(CHIBIOS)/os/common/ports/ARMCMx/compilers/GCC
  77. ifeq ("$(wildcard $(RULESPATH)/rules.mk)","")
  78. RULESPATH = $(CHIBIOS)/os/common/startup/ARMCMx/compilers/GCC
  79. endif
  80. # Define linker script file here
  81. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/ld/$(MCU_LDSCRIPT).ld)","")
  82. LDSCRIPT = $(KEYBOARD_PATH_5)/ld/$(MCU_LDSCRIPT).ld
  83. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/ld/$(MCU_LDSCRIPT).ld)","")
  84. LDSCRIPT = $(KEYBOARD_PATH_4)/ld/$(MCU_LDSCRIPT).ld
  85. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/ld/$(MCU_LDSCRIPT).ld)","")
  86. LDSCRIPT = $(KEYBOARD_PATH_3)/ld/$(MCU_LDSCRIPT).ld
  87. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/ld/$(MCU_LDSCRIPT).ld)","")
  88. LDSCRIPT = $(KEYBOARD_PATH_2)/ld/$(MCU_LDSCRIPT).ld
  89. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/ld/$(MCU_LDSCRIPT).ld)","")
  90. LDSCRIPT = $(KEYBOARD_PATH_1)/ld/$(MCU_LDSCRIPT).ld
  91. else
  92. LDSCRIPT = $(STARTUPLD)/$(MCU_LDSCRIPT).ld
  93. endif
  94. CHIBISRC = $(STARTUPSRC) \
  95. $(KERNSRC) \
  96. $(PORTSRC) \
  97. $(OSALSRC) \
  98. $(HALSRC) \
  99. $(PLATFORMSRC) \
  100. $(BOARDSRC) \
  101. $(STREAMSSRC) \
  102. $(STARTUPASM) \
  103. $(PORTASM) \
  104. $(OSALASM)
  105. CHIBISRC := $(patsubst $(TOP_DIR)/%,%,$(CHIBISRC))
  106. EXTRAINCDIRS += $(CHIBIOS)/os/license \
  107. $(STARTUPINC) $(KERNINC) $(PORTINC) $(OSALINC) \
  108. $(HALINC) $(PLATFORMINC) $(BOARDINC) $(TESTINC) \
  109. $(STREAMSINC) $(CHIBIOS)/os/various
  110. #
  111. # Project, sources and paths
  112. ##############################################################################
  113. ##############################################################################
  114. # Compiler settings
  115. #
  116. CC = arm-none-eabi-gcc
  117. OBJCOPY = arm-none-eabi-objcopy
  118. OBJDUMP = arm-none-eabi-objdump
  119. SIZE = arm-none-eabi-size
  120. AR = arm-none-eabi-ar
  121. NM = arm-none-eabi-nm
  122. HEX = $(OBJCOPY) -O $(FORMAT)
  123. EEP =
  124. BIN = $(OBJCOPY) -O binary
  125. THUMBFLAGS = -DTHUMB_PRESENT -mno-thumb-interwork -DTHUMB_NO_INTERWORKING -mthumb -DTHUMB
  126. COMPILEFLAGS += -fomit-frame-pointer
  127. COMPILEFLAGS += -falign-functions=16
  128. COMPILEFLAGS += -ffunction-sections
  129. COMPILEFLAGS += -fdata-sections
  130. COMPILEFLAGS += -fno-common
  131. COMPILEFLAGS += $(THUMBFLAGS)
  132. CFLAGS += $(COMPILEFLAGS)
  133. ASFLAGS += $(THUMBFLAGS)
  134. CPPFLAGS += $(COMPILEFLAGS)
  135. CPPFLAGS += -fno-rtti
  136. LDFLAGS +=-Wl,--gc-sections
  137. LDFLAGS += -mno-thumb-interwork -mthumb
  138. LDSYMBOLS =,--defsym=__process_stack_size__=$(USE_PROCESS_STACKSIZE)
  139. LDSYMBOLS :=$(LDSYMBOLS),--defsym=__main_stack_size__=$(USE_EXCEPTIONS_STACKSIZE)
  140. LDFLAGS += -Wl,--script=$(LDSCRIPT)$(LDSYMBOLS)
  141. OPT_DEFS += -DPROTOCOL_CHIBIOS
  142. MCUFLAGS = -mcpu=$(MCU)
  143. # FPU options default (Cortex-M4 and Cortex-M7 single precision).
  144. ifeq ($(USE_FPU_OPT),)
  145. USE_FPU_OPT = -mfloat-abi=$(USE_FPU) -mfpu=fpv4-sp-d16 -fsingle-precision-constant
  146. endif
  147. # FPU-related options
  148. ifeq ($(USE_FPU),)
  149. USE_FPU = no
  150. endif
  151. ifneq ($(USE_FPU),no)
  152. OPT += $(USE_FPU_OPT)
  153. OPT_DEFS += -DCORTEX_USE_FPU=TRUE
  154. else
  155. OPT_DEFS += -DCORTEX_USE_FPU=FALSE
  156. endif
  157. DEBUG = gdb
  158. DFU_ARGS ?=
  159. ifneq ("$(SERIAL)","")
  160. DFU_ARGS += -S $(SERIAL)
  161. endif
  162. # List any extra directories to look for libraries here.
  163. EXTRALIBDIRS = $(RULESPATH)/ld
  164. DFU_UTIL ?= dfu-util
  165. # Generate a .qmk for the QMK-FF
  166. qmk: $(BUILD_DIR)/$(TARGET).bin
  167. zip $(TARGET).qmk -FSrj $(KEYMAP_PATH)/*
  168. zip $(TARGET).qmk -u $<
  169. printf "@ $<\n@=firmware.bin\n" | zipnote -w $(TARGET).qmk
  170. printf "{\n \"generated\": \"%s\"\n}" "$$(date)" > $(BUILD_DIR)/$(TARGET).json
  171. if [ -f $(KEYBOARD_PATH_5)/info.json ]; then \
  172. jq -s '.[0] * .[1]' $(BUILD_DIR)/$(TARGET).json $(KEYBOARD_PATH_5)/info.json | ex -sc 'wq!$(BUILD_DIR)/$(TARGET).json' /dev/stdin; \
  173. fi
  174. if [ -f $(KEYBOARD_PATH_4)/info.json ]; then \
  175. jq -s '.[0] * .[1]' $(BUILD_DIR)/$(TARGET).json $(KEYBOARD_PATH_4)/info.json | ex -sc 'wq!$(BUILD_DIR)/$(TARGET).json' /dev/stdin; \
  176. fi
  177. if [ -f $(KEYBOARD_PATH_3)/info.json ]; then \
  178. jq -s '.[0] * .[1]' $(BUILD_DIR)/$(TARGET).json $(KEYBOARD_PATH_3)/info.json | ex -sc 'wq!$(BUILD_DIR)/$(TARGET).json' /dev/stdin; \
  179. fi
  180. if [ -f $(KEYBOARD_PATH_2)/info.json ]; then \
  181. jq -s '.[0] * .[1]' $(BUILD_DIR)/$(TARGET).json $(KEYBOARD_PATH_2)/info.json | ex -sc 'wq!$(BUILD_DIR)/$(TARGET).json' /dev/stdin; \
  182. fi
  183. if [ -f $(KEYBOARD_PATH_1)/info.json ]; then \
  184. jq -s '.[0] * .[1]' $(BUILD_DIR)/$(TARGET).json $(KEYBOARD_PATH_1)/info.json | ex -sc 'wq!$(BUILD_DIR)/$(TARGET).json' /dev/stdin; \
  185. fi
  186. zip $(TARGET).qmk -urj $(BUILD_DIR)/$(TARGET).json
  187. printf "@ $(TARGET).json\n@=info.json\n" | zipnote -w $(TARGET).qmk
  188. dfu-util: $(BUILD_DIR)/$(TARGET).bin cpfirmware sizeafter
  189. $(DFU_UTIL) $(DFU_ARGS) -D $(BUILD_DIR)/$(TARGET).bin
  190. bin: $(BUILD_DIR)/$(TARGET).bin sizeafter
  191. $(COPY) $(BUILD_DIR)/$(TARGET).bin $(TARGET).bin;