You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

321 lines
11 KiB

Merge ChibiOS and LUFA descriptor support (#2362) * Move lufa descriptor to protocol/usb_descriptor * Try to compile usb_descriptor on ChibiOS * Add lufa_utils for ChibiOS Lufa USB descriptors for ChibiOS * More lufa_util compatibility fixes * First compiling version of shared USB descriptor * Send the usb descriptors * Fix the CONSOLE output on ChibiOS * Add errors for unsupported interfaces * Enable support for vitual serial port USB descriptors * Implement virtual serial port for ChibiOS * Cleanup the lufa_utils Use the default lufa header files * Add raw hid support for ChibiOS This is completely untested * Enable midi compilation on ChibiOS * Move midi functionality out of lufa.c * Don't register sysex callback when not needed * ChibiOS compilation fixes * Update ChibiOS submodule * Fix the Midi USB descriptor It didn't work properly when both Midi and Virtual serial port was enabled. * Add MIDI support for ChibiOS * Fix USB descriptor strings on ChibiOS * Use serial usb driver for raw hid * Generalize the ChibiOS stream like drivers This makes the initialization much more simple and eliminates a lot of the code duplication. * Convert console output to chibios stream driver * Fixes for ChibiOS update * Update the ChibiOS contrib submodule To include the usb data toggle synchronization fixes * Fix duplicate reset enumeration on ChibiOS * Add missing include * Add number of endpoints check for ChibiOS * Enable serial USB driver on all keyboards * Add missing includes when API is enabled withot midi * Add another missing inlcude
6 years ago
6 years ago
6 years ago
Merge ChibiOS and LUFA descriptor support (#2362) * Move lufa descriptor to protocol/usb_descriptor * Try to compile usb_descriptor on ChibiOS * Add lufa_utils for ChibiOS Lufa USB descriptors for ChibiOS * More lufa_util compatibility fixes * First compiling version of shared USB descriptor * Send the usb descriptors * Fix the CONSOLE output on ChibiOS * Add errors for unsupported interfaces * Enable support for vitual serial port USB descriptors * Implement virtual serial port for ChibiOS * Cleanup the lufa_utils Use the default lufa header files * Add raw hid support for ChibiOS This is completely untested * Enable midi compilation on ChibiOS * Move midi functionality out of lufa.c * Don't register sysex callback when not needed * ChibiOS compilation fixes * Update ChibiOS submodule * Fix the Midi USB descriptor It didn't work properly when both Midi and Virtual serial port was enabled. * Add MIDI support for ChibiOS * Fix USB descriptor strings on ChibiOS * Use serial usb driver for raw hid * Generalize the ChibiOS stream like drivers This makes the initialization much more simple and eliminates a lot of the code duplication. * Convert console output to chibios stream driver * Fixes for ChibiOS update * Update the ChibiOS contrib submodule To include the usb data toggle synchronization fixes * Fix duplicate reset enumeration on ChibiOS * Add missing include * Add number of endpoints check for ChibiOS * Enable serial USB driver on all keyboards * Add missing includes when API is enabled withot midi * Add another missing inlcude
6 years ago
  1. ifndef VERBOSE
  2. .SILENT:
  3. endif
  4. .DEFAULT_GOAL := all
  5. include common.mk
  6. # 5/4/3/2/1
  7. KEYBOARD_FOLDER_PATH_1 := $(KEYBOARD)
  8. KEYBOARD_FOLDER_PATH_2 := $(patsubst %/,%,$(dir $(KEYBOARD_FOLDER_PATH_1)))
  9. KEYBOARD_FOLDER_PATH_3 := $(patsubst %/,%,$(dir $(KEYBOARD_FOLDER_PATH_2)))
  10. KEYBOARD_FOLDER_PATH_4 := $(patsubst %/,%,$(dir $(KEYBOARD_FOLDER_PATH_3)))
  11. KEYBOARD_FOLDER_PATH_5 := $(patsubst %/,%,$(dir $(KEYBOARD_FOLDER_PATH_4)))
  12. KEYBOARD_FOLDER_1 := $(notdir $(KEYBOARD_FOLDER_PATH_1))
  13. KEYBOARD_FOLDER_2 := $(notdir $(KEYBOARD_FOLDER_PATH_2))
  14. KEYBOARD_FOLDER_3 := $(notdir $(KEYBOARD_FOLDER_PATH_3))
  15. KEYBOARD_FOLDER_4 := $(notdir $(KEYBOARD_FOLDER_PATH_4))
  16. KEYBOARD_FOLDER_5 := $(notdir $(KEYBOARD_FOLDER_PATH_5))
  17. KEYBOARD_FILESAFE := $(subst /,_,$(KEYBOARD))
  18. KEYMAP_FILESAFE := $(subst /,_,$(KEYMAP))
  19. TARGET ?= $(KEYBOARD_FILESAFE)_$(KEYMAP_FILESAFE)
  20. KEYBOARD_OUTPUT := $(BUILD_DIR)/obj_$(KEYBOARD_FILESAFE)
  21. # Force expansion
  22. TARGET := $(TARGET)
  23. MASTER ?= left
  24. ifdef master
  25. MASTER = $(master)
  26. endif
  27. ifeq ($(MASTER),right)
  28. OPT_DEFS += -DMASTER_IS_ON_RIGHT
  29. else
  30. ifneq ($(MASTER),left)
  31. $(error MASTER does not have a valid value(left/right))
  32. endif
  33. endif
  34. KEYBOARD_PATHS :=
  35. KEYBOARD_PATH_1 := keyboards/$(KEYBOARD_FOLDER_PATH_1)
  36. KEYBOARD_PATH_2 := keyboards/$(KEYBOARD_FOLDER_PATH_2)
  37. KEYBOARD_PATH_3 := keyboards/$(KEYBOARD_FOLDER_PATH_3)
  38. KEYBOARD_PATH_4 := keyboards/$(KEYBOARD_FOLDER_PATH_4)
  39. KEYBOARD_PATH_5 := keyboards/$(KEYBOARD_FOLDER_PATH_5)
  40. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/rules.mk)","")
  41. KEYBOARD_PATHS += $(KEYBOARD_PATH_5)
  42. include $(KEYBOARD_PATH_5)/rules.mk
  43. endif
  44. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/rules.mk)","")
  45. KEYBOARD_PATHS += $(KEYBOARD_PATH_4)
  46. include $(KEYBOARD_PATH_4)/rules.mk
  47. endif
  48. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/rules.mk)","")
  49. KEYBOARD_PATHS += $(KEYBOARD_PATH_3)
  50. include $(KEYBOARD_PATH_3)/rules.mk
  51. endif
  52. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/rules.mk)","")
  53. KEYBOARD_PATHS += $(KEYBOARD_PATH_2)
  54. include $(KEYBOARD_PATH_2)/rules.mk
  55. endif
  56. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/rules.mk)","")
  57. KEYBOARD_PATHS += $(KEYBOARD_PATH_1)
  58. include $(KEYBOARD_PATH_1)/rules.mk
  59. endif
  60. KEYBOARD_SRC :=
  61. KEYBOARD_C_1 := $(KEYBOARD_PATH_1)/$(KEYBOARD_FOLDER_1).c
  62. KEYBOARD_C_2 := $(KEYBOARD_PATH_2)/$(KEYBOARD_FOLDER_2).c
  63. KEYBOARD_C_3 := $(KEYBOARD_PATH_3)/$(KEYBOARD_FOLDER_3).c
  64. KEYBOARD_C_4 := $(KEYBOARD_PATH_4)/$(KEYBOARD_FOLDER_4).c
  65. KEYBOARD_C_5 := $(KEYBOARD_PATH_5)/$(KEYBOARD_FOLDER_5).c
  66. ifneq ("$(wildcard $(KEYBOARD_C_5))","")
  67. KEYBOARD_SRC += $(KEYBOARD_C_5)
  68. endif
  69. ifneq ("$(wildcard $(KEYBOARD_C_4))","")
  70. KEYBOARD_SRC += $(KEYBOARD_C_4)
  71. endif
  72. ifneq ("$(wildcard $(KEYBOARD_C_3))","")
  73. KEYBOARD_SRC += $(KEYBOARD_C_3)
  74. endif
  75. ifneq ("$(wildcard $(KEYBOARD_C_2))","")
  76. KEYBOARD_SRC += $(KEYBOARD_C_2)
  77. endif
  78. ifneq ("$(wildcard $(KEYBOARD_C_1))","")
  79. KEYBOARD_SRC += $(KEYBOARD_C_1)
  80. endif
  81. OPT_DEFS += -DKEYBOARD_$(KEYBOARD_FILESAFE)
  82. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/$(KEYBOARD_FOLDER_1).h)","")
  83. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_1).h
  84. endif
  85. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/$(KEYBOARD_FOLDER_2).h)","")
  86. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_2).h
  87. endif
  88. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/$(KEYBOARD_FOLDER_3).h)","")
  89. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_3).h
  90. endif
  91. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/$(KEYBOARD_FOLDER_4).h)","")
  92. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_4).h
  93. endif
  94. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/$(KEYBOARD_FOLDER_5).h)","")
  95. QMK_KEYBOARD_H = $(KEYBOARD_FOLDER_5).h
  96. endif
  97. # We can assume a ChibiOS target When MCU_FAMILY is defined , since it's not used for LUFA
  98. ifdef MCU_FAMILY
  99. FIRMWARE_FORMAT=bin
  100. PLATFORM=CHIBIOS
  101. else
  102. PLATFORM=AVR
  103. FIRMWARE_FORMAT=hex
  104. endif
  105. ifeq ($(PLATFORM),CHIBIOS)
  106. include $(TMK_PATH)/chibios.mk
  107. OPT_OS = chibios
  108. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/bootloader_defs.h)","")
  109. OPT_DEFS += -include $(KEYBOARD_PATH_5)/bootloader_defs.h
  110. else ifneq ("$(wildcard $(KEYBOARD_PATH_5)/boards/$(BOARD)/bootloader_defs.h)","")
  111. OPT_DEFS += -include $(KEYBOARD_PATH_5)/boards/$(BOARD)/bootloader_defs.h
  112. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/bootloader_defs.h)","")
  113. OPT_DEFS += -include $(KEYBOARD_PATH_4)/bootloader_defs.h
  114. else ifneq ("$(wildcard $(KEYBOARD_PATH_4)/boards/$(BOARD)/bootloader_defs.h)","")
  115. OPT_DEFS += -include $(KEYBOARD_PATH_4)/boards/$(BOARD)/bootloader_defs.h
  116. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/bootloader_defs.h)","")
  117. OPT_DEFS += -include $(KEYBOARD_PATH_3)/bootloader_defs.h
  118. else ifneq ("$(wildcard $(KEYBOARD_PATH_3)/boards/$(BOARD)/bootloader_defs.h)","")
  119. OPT_DEFS += -include $(KEYBOARD_PATH_3)/boards/$(BOARD)/bootloader_defs.h
  120. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/bootloader_defs.h)","")
  121. OPT_DEFS += -include $(KEYBOARD_PATH_2)/bootloader_defs.h
  122. else ifneq ("$(wildcard $(KEYBOARD_PATH_2)/boards/$(BOARD)/bootloader_defs.h)","")
  123. OPT_DEFS += -include $(KEYBOARD_PATH_2)/boards/$(BOARD)/bootloader_defs.h
  124. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/bootloader_defs.h)","")
  125. OPT_DEFS += -include $(KEYBOARD_PATH_1)/bootloader_defs.h
  126. else ifneq ("$(wildcard $(KEYBOARD_PATH_1)/boards/$(BOARD)/bootloader_defs.h)","")
  127. OPT_DEFS += -include $(KEYBOARD_PATH_1)/boards/$(BOARD)/bootloader_defs.h
  128. else ifneq ("$(wildcard $(TOP_DIR)/drivers/boards/$(BOARD)/bootloader_defs.h)","")
  129. OPT_DEFS += -include $(TOP_DIR)/drivers/boards/$(BOARD)/bootloader_defs.h
  130. endif
  131. endif
  132. CONFIG_H :=
  133. ifneq ("$(wildcard $(KEYBOARD_PATH_5)/config.h)","")
  134. CONFIG_H += $(KEYBOARD_PATH_5)/config.h
  135. endif
  136. ifneq ("$(wildcard $(KEYBOARD_PATH_4)/config.h)","")
  137. CONFIG_H += $(KEYBOARD_PATH_4)/config.h
  138. endif
  139. ifneq ("$(wildcard $(KEYBOARD_PATH_3)/config.h)","")
  140. CONFIG_H += $(KEYBOARD_PATH_3)/config.h
  141. endif
  142. ifneq ("$(wildcard $(KEYBOARD_PATH_2)/config.h)","")
  143. CONFIG_H += $(KEYBOARD_PATH_2)/config.h
  144. endif
  145. ifneq ("$(wildcard $(KEYBOARD_PATH_1)/config.h)","")
  146. CONFIG_H += $(KEYBOARD_PATH_1)/config.h
  147. endif
  148. # Save the defines and includes here, so we don't include any keymap specific ones
  149. PROJECT_DEFS := $(OPT_DEFS)
  150. PROJECT_INC := $(VPATH) $(EXTRAINCDIRS) $(KEYBOARD_PATHS)
  151. PROJECT_CONFIG := $(CONFIG_H)
  152. MAIN_KEYMAP_PATH_1 := $(KEYBOARD_PATH_1)/keymaps/$(KEYMAP)
  153. MAIN_KEYMAP_PATH_2 := $(KEYBOARD_PATH_2)/keymaps/$(KEYMAP)
  154. MAIN_KEYMAP_PATH_3 := $(KEYBOARD_PATH_3)/keymaps/$(KEYMAP)
  155. MAIN_KEYMAP_PATH_4 := $(KEYBOARD_PATH_4)/keymaps/$(KEYMAP)
  156. MAIN_KEYMAP_PATH_5 := $(KEYBOARD_PATH_5)/keymaps/$(KEYMAP)
  157. PARENT_MAIN_KEYMAP_PATH_1 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_1)))
  158. PARENT_MAIN_KEYMAP_PATH_2 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_2)))
  159. PARENT_MAIN_KEYMAP_PATH_3 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_3)))
  160. PARENT_MAIN_KEYMAP_PATH_4 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_4)))
  161. PARENT_MAIN_KEYMAP_PATH_5 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_5)))
  162. # $(info $(PARENT_MAIN_KEYMAP_PATH_1))
  163. ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_5)/keymap.c)","")
  164. KEYMAP_C := $(MAIN_KEYMAP_PATH_5)/keymap.c
  165. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_5)
  166. else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_5)/keymap.c)","")
  167. KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_5)/keymap.c
  168. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_5)
  169. else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_4)/keymap.c)","")
  170. KEYMAP_C := $(MAIN_KEYMAP_PATH_4)/keymap.c
  171. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_4)
  172. else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_4)/keymap.c)","")
  173. KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_4)/keymap.c
  174. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_4)
  175. else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_3)/keymap.c)","")
  176. KEYMAP_C := $(MAIN_KEYMAP_PATH_3)/keymap.c
  177. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_3)
  178. else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_3)/keymap.c)","")
  179. KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_3)/keymap.c
  180. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_3)
  181. else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_2)/keymap.c)","")
  182. KEYMAP_C := $(MAIN_KEYMAP_PATH_2)/keymap.c
  183. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_2)
  184. else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_2)/keymap.c)","")
  185. KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_2)/keymap.c
  186. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_2)
  187. else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_1)/keymap.c)","")
  188. KEYMAP_C := $(MAIN_KEYMAP_PATH_1)/keymap.c
  189. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_1)
  190. else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_1)/keymap.c)","")
  191. KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_1)/keymap.c
  192. KEYMAP_PATH := $(MAIN_KEYMAP_PATH_1)
  193. else ifneq ($(LAYOUTS),)
  194. include build_layout.mk
  195. else
  196. $(error Could not find keymap)
  197. # this state should never be reached
  198. endif
  199. PARENT_KEYMAP_PATH := $(patsubst %/,%,$(dir $(KEYMAP_PATH)))
  200. # User space stuff
  201. ifeq ("$(USER_NAME)","")
  202. USER_NAME := $(KEYMAP)
  203. endif
  204. USER_PATH := users/$(USER_NAME)
  205. # Object files directory
  206. # To put object files in current directory, use a dot (.), do NOT make
  207. # this an empty or blank macro!
  208. KEYMAP_OUTPUT := $(BUILD_DIR)/obj_$(TARGET)
  209. -include $(PARENT_KEYMAP_PATH)/rules.mk
  210. -include $(KEYMAP_PATH)/rules.mk
  211. -include $(USER_PATH)/rules.mk
  212. ifneq ("$(wildcard $(PARENT_KEYMAP_PATH)/config.h)","")
  213. CONFIG_H += $(PARENT_KEYMAP_PATH)/config.h
  214. endif
  215. ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","")
  216. CONFIG_H += $(KEYMAP_PATH)/config.h
  217. endif
  218. ifneq ("$(wildcard $(USER_PATH)/config.h)","")
  219. CONFIG_H += $(USER_PATH)/config.h
  220. endif
  221. # # project specific files
  222. SRC += $(KEYBOARD_SRC) \
  223. $(KEYMAP_C) \
  224. $(QUANTUM_SRC)
  225. # Optimize size but this may cause error "relocation truncated to fit"
  226. #EXTRALDFLAGS = -Wl,--relax
  227. # Search Path
  228. VPATH += $(PARENT_KEYMAP_PATH)
  229. VPATH += $(KEYMAP_PATH)
  230. VPATH += $(KEYBOARD_PATHS)
  231. VPATH += $(COMMON_VPATH)
  232. VPATH += $(USER_PATH)
  233. include common_features.mk
  234. include $(TMK_PATH)/protocol.mk
  235. include $(TMK_PATH)/common.mk
  236. include bootloader.mk
  237. SRC += $(TMK_COMMON_SRC)
  238. OPT_DEFS += $(TMK_COMMON_DEFS)
  239. EXTRALDFLAGS += $(TMK_COMMON_LDFLAGS)
  240. ifeq ($(PLATFORM),AVR)
  241. ifeq ($(strip $(PROTOCOL)), VUSB)
  242. include $(TMK_PATH)/protocol/vusb.mk
  243. else
  244. include $(TMK_PATH)/protocol/lufa.mk
  245. endif
  246. include $(TMK_PATH)/avr.mk
  247. endif
  248. ifeq ($(PLATFORM),CHIBIOS)
  249. include $(TMK_PATH)/protocol/chibios.mk
  250. endif
  251. ifeq ($(strip $(VISUALIZER_ENABLE)), yes)
  252. VISUALIZER_DIR = $(QUANTUM_DIR)/visualizer
  253. VISUALIZER_PATH = $(QUANTUM_PATH)/visualizer
  254. include $(VISUALIZER_PATH)/visualizer.mk
  255. endif
  256. ALL_CONFIGS := $(PROJECT_CONFIG) $(CONFIG_H)
  257. OUTPUTS := $(KEYMAP_OUTPUT) $(KEYBOARD_OUTPUT)
  258. $(KEYMAP_OUTPUT)_SRC := $(SRC)
  259. $(KEYMAP_OUTPUT)_DEFS := $(OPT_DEFS) $(GFXDEFS) \
  260. -DQMK_KEYBOARD=\"$(KEYBOARD)\" -DQMK_KEYBOARD_H=\"$(QMK_KEYBOARD_H)\" -DQMK_KEYBOARD_CONFIG_H=\"$(KEYBOARD_PATH_1)/config.h\" \
  261. -DQMK_KEYMAP=\"$(KEYMAP)\" -DQMK_KEYMAP_H=\"$(KEYMAP).h\" -DQMK_KEYMAP_CONFIG_H=\"$(KEYMAP_PATH)/config.h\" \
  262. -DQMK_SUBPROJECT -DQMK_SUBPROJECT_H -DQMK_SUBPROJECT_CONFIG_H
  263. $(KEYMAP_OUTPUT)_INC := $(VPATH) $(EXTRAINCDIRS)
  264. $(KEYMAP_OUTPUT)_CONFIG := $(CONFIG_H)
  265. $(KEYBOARD_OUTPUT)_SRC := $(CHIBISRC) $(GFXSRC)
  266. $(KEYBOARD_OUTPUT)_DEFS := $(PROJECT_DEFS) $(GFXDEFS)
  267. $(KEYBOARD_OUTPUT)_INC := $(PROJECT_INC) $(GFXINC)
  268. $(KEYBOARD_OUTPUT)_CONFIG := $(PROJECT_CONFIG)
  269. # Default target.
  270. all: build check-size
  271. # Change the build target to build a HEX file or a library.
  272. build: elf cpfirmware
  273. #build: elf hex eep lss sym
  274. #build: lib
  275. include $(TMK_PATH)/rules.mk