10 TARGET ?
= $(KEYBOARD
)_
$(SUBPROJECT
)_
$(KEYMAP
)
11 KEYBOARD_OUTPUT
:= $(BUILD_DIR
)/obj_
$(KEYBOARD
)_
$(SUBPROJECT
)
13 TARGET ?
= $(KEYBOARD
)_
$(KEYMAP
)
14 KEYBOARD_OUTPUT
:= $(BUILD_DIR
)/obj_
$(KEYBOARD
)
26 ifeq ($(MASTER
),right
)
27 OPT_DEFS
+= -DMASTER_IS_ON_RIGHT
29 ifneq ($(MASTER
),left
)
30 $(error MASTER does not have a valid value
(left
/right
))
36 KEYBOARD_PATH
:= keyboards
/$(KEYBOARD
)
37 KEYBOARD_C
:= $(KEYBOARD_PATH
)/$(KEYBOARD
).c
39 ifneq ("$(wildcard $(KEYBOARD_C))","")
40 include $(KEYBOARD_PATH
)/rules.mk
42 $(error
"$(KEYBOARD_C)" does not exist
)
46 ifneq ($(SUBPROJECT
),)
47 SUBPROJECT_PATH
:= keyboards
/$(KEYBOARD
)/$(SUBPROJECT
)
48 SUBPROJECT_C
:= $(SUBPROJECT_PATH
)/$(SUBPROJECT
).c
49 ifneq ("$(wildcard $(SUBPROJECT_C))","")
50 OPT_DEFS
+= -DSUBPROJECT_
$(SUBPROJECT
)
51 include $(SUBPROJECT_PATH
)/rules.mk
53 $(error
"$(SUBPROJECT_PATH)/$(SUBPROJECT).c" does not exist
)
57 # We can assume a ChibiOS target When MCU_FAMILY is defined, since it's not used for LUFA
64 ifeq ($(PLATFORM
),CHIBIOS
)
65 include $(TMK_PATH
)/protocol
/chibios.mk
66 include $(TMK_PATH
)/chibios.mk
68 ifneq ("$(wildcard $(SUBPROJECT_PATH)/bootloader_defs.h)","")
69 OPT_DEFS
+= -include $(SUBPROJECT_PATH
)/bootloader_defs.h
70 else ifneq ("$(wildcard $(SUBPROJECT_PATH)/boards/$(BOARD)/bootloader_defs.h)","")
71 OPT_DEFS
+= -include $(SUBPROJECT_PATH
)/boards
/$(BOARD
)/bootloader_defs.h
72 else ifneq ("$(wildcard $(KEYBOARD_PATH)/bootloader_defs.h)","")
73 OPT_DEFS
+= -include $(KEYBOARD_PATH
)/bootloader_defs.h
74 else ifneq ("$(wildcard $(KEYBOARD_PATH)/boards/$(BOARD)/bootloader_defs.h)","")
75 OPT_DEFS
+= -include $(KEYBOARD_PATH
)/boards
/$(BOARD
)/bootloader_defs.h
79 CONFIG_H
= $(KEYBOARD_PATH
)/config.h
80 ifneq ($(SUBPROJECT
),)
81 ifneq ("$(wildcard $(SUBPROJECT_C))","")
82 CONFIG_H
= $(SUBPROJECT_PATH
)/config.h
86 # Save the defines and includes here, so we don't include any keymap specific ones
87 PROJECT_DEFS
:= $(OPT_DEFS
)
88 PROJECT_INC
:= $(VPATH
) $(EXTRAINCDIRS
) $(SUBPROJECT_PATH
) $(KEYBOARD_PATH
)
89 PROJECT_CONFIG
:= $(CONFIG_H
)
91 MAIN_KEYMAP_PATH
:= $(KEYBOARD_PATH
)/keymaps
/$(KEYMAP
)
92 MAIN_KEYMAP_C
:= $(MAIN_KEYMAP_PATH
)/keymap.c
93 SUBPROJ_KEYMAP_PATH
:= $(SUBPROJECT_PATH
)/keymaps
/$(KEYMAP
)
94 SUBPROJ_KEYMAP_C
:= $(SUBPROJ_KEYMAP_PATH
)/keymap.c
95 ifneq ("$(wildcard $(SUBPROJ_KEYMAP_C))","")
96 -include $(SUBPROJ_KEYMAP_PATH
)/Makefile
97 KEYMAP_C
:= $(SUBPROJ_KEYMAP_C
)
98 KEYMAP_PATH
:= $(SUBPROJ_KEYMAP_PATH
)
99 else ifneq ("$(wildcard $(MAIN_KEYMAP_C))","")
100 -include $(MAIN_KEYMAP_PATH
)/Makefile
101 KEYMAP_C
:= $(MAIN_KEYMAP_C
)
102 KEYMAP_PATH
:= $(MAIN_KEYMAP_PATH
)
104 $(error
"$(MAIN_KEYMAP_C)/keymap.c" does not exist
)
108 # Object files directory
109 # To put object files in current directory, use a dot (.), do NOT make
110 # this an empty or blank macro!
111 KEYMAP_OUTPUT
:= $(BUILD_DIR
)/obj_
$(TARGET
)
114 ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","")
115 CONFIG_H
= $(KEYMAP_PATH
)/config.h
118 # # project specific files
119 SRC
+= $(KEYBOARD_C
) \
121 $(QUANTUM_DIR
)/quantum.c \
122 $(QUANTUM_DIR
)/keymap_common.c \
123 $(QUANTUM_DIR
)/keycode_config.c \
124 $(QUANTUM_DIR
)/process_keycode
/process_leader.c
126 ifneq ($(SUBPROJECT
),)
127 SRC
+= $(SUBPROJECT_C
)
131 SRC
+= $(QUANTUM_DIR
)/matrix.c
134 ifeq ($(strip $(API_SYSEX_ENABLE
)), yes
)
135 OPT_DEFS
+= -DAPI_SYSEX_ENABLE
136 SRC
+= $(QUANTUM_DIR
)/api
/api_sysex.c
137 OPT_DEFS
+= -DAPI_ENABLE
138 SRC
+= $(QUANTUM_DIR
)/api.c
144 ifeq ($(strip $(AUDIO_ENABLE
)), yes
)
145 OPT_DEFS
+= -DAUDIO_ENABLE
147 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_audio.c
148 SRC
+= $(QUANTUM_DIR
)/audio
/audio.c
149 SRC
+= $(QUANTUM_DIR
)/audio
/voices.c
150 SRC
+= $(QUANTUM_DIR
)/audio
/luts.c
153 ifeq ($(strip $(MIDI_ENABLE
)), yes
)
154 OPT_DEFS
+= -DMIDI_ENABLE
156 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_midi.c
159 ifeq ($(MUSIC_ENABLE
), 1)
160 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_music.c
163 ifeq ($(strip $(COMBO_ENABLE
)), yes
)
164 OPT_DEFS
+= -DCOMBO_ENABLE
165 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_combo.c
168 ifeq ($(strip $(VIRTSER_ENABLE
)), yes
)
169 OPT_DEFS
+= -DVIRTSER_ENABLE
172 ifeq ($(strip $(FAUXCLICKY_ENABLE
)), yes
)
173 OPT_DEFS
+= -DFAUXCLICKY_ENABLE
174 SRC
+= $(QUANTUM_DIR
)/fauxclicky.c
177 ifeq ($(strip $(UCIS_ENABLE
)), yes
)
178 OPT_DEFS
+= -DUCIS_ENABLE
180 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_ucis.c
183 ifeq ($(strip $(UNICODEMAP_ENABLE
)), yes
)
184 OPT_DEFS
+= -DUNICODEMAP_ENABLE
186 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_unicodemap.c
189 ifeq ($(strip $(UNICODE_ENABLE
)), yes
)
190 OPT_DEFS
+= -DUNICODE_ENABLE
192 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_unicode.c
195 ifeq ($(strip $(UNICODE_COMMON
)), yes
)
196 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_unicode_common.c
199 ifeq ($(strip $(RGBLIGHT_ENABLE
)), yes
)
200 OPT_DEFS
+= -DRGBLIGHT_ENABLE
201 SRC
+= $(QUANTUM_DIR
)/light_ws2812.c
202 SRC
+= $(QUANTUM_DIR
)/rgblight.c
204 LED_BREATHING_TABLE
= yes
207 ifeq ($(strip $(TAP_DANCE_ENABLE
)), yes
)
208 OPT_DEFS
+= -DTAP_DANCE_ENABLE
209 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_tap_dance.c
212 ifeq ($(strip $(PRINTING_ENABLE
)), yes
)
213 OPT_DEFS
+= -DPRINTING_ENABLE
214 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_printer.c
215 SRC
+= $(TMK_DIR
)/protocol
/serial_uart.c
218 ifeq ($(strip $(SERIAL_LINK_ENABLE
)), yes
)
219 SRC
+= $(patsubst $(QUANTUM_PATH
)/%,%,$(SERIAL_SRC
))
220 OPT_DEFS
+= $(SERIAL_DEFS
)
221 VAPTH
+= $(SERIAL_PATH
)
224 ifneq ($(strip $(VARIABLE_TRACE
)),)
225 SRC
+= $(QUANTUM_DIR
)/variable_trace.c
226 OPT_DEFS
+= -DNUM_TRACED_VARIABLES
=$(strip $(VARIABLE_TRACE
))
227 ifneq ($(strip $(MAX_VARIABLE_TRACE_SIZE
)),)
228 OPT_DEFS
+= -DMAX_VARIABLE_TRACE_SIZE
=$(strip $(MAX_VARIABLE_TRACE_SIZE
))
232 ifeq ($(strip $(LCD_ENABLE
)), yes
)
236 ifeq ($(strip $(LED_ENABLE
)), yes
)
240 ifeq ($(strip $(CIE1931_CURVE
)), yes
)
241 OPT_DEFS
+= -DUSE_CIE1931_CURVE
245 ifeq ($(strip $(LED_BREATHING_TABLE
)), yes
)
246 OPT_DEFS
+= -DUSE_LED_BREATHING_TABLE
250 ifeq ($(strip $(LED_TABLES
)), yes
)
251 SRC
+= $(QUANTUM_DIR
)/led_tables.c
254 # Optimize size but this may cause error "relocation truncated to fit"
255 #EXTRALDFLAGS = -Wl,--relax
258 VPATH
+= $(KEYMAP_PATH
)
259 ifneq ($(SUBPROJECT
),)
260 VPATH
+= $(SUBPROJECT_PATH
)
262 VPATH
+= $(KEYBOARD_PATH
)
263 VPATH
+= $(COMMON_VPATH
)
265 include $(TMK_PATH
)/protocol.mk
267 include $(TMK_PATH
)/common.mk
268 SRC
+= $(TMK_COMMON_SRC
)
269 OPT_DEFS
+= $(TMK_COMMON_DEFS
)
270 EXTRALDFLAGS
+= $(TMK_COMMON_LDFLAGS
)
272 ifeq ($(PLATFORM
),AVR
)
273 ifeq ($(strip $(PROTOCOL
)), VUSB
)
274 include $(TMK_PATH
)/protocol
/vusb.mk
276 include $(TMK_PATH
)/protocol
/lufa.mk
278 include $(TMK_PATH
)/avr.mk
281 ifeq ($(strip $(VISUALIZER_ENABLE
)), yes
)
282 VISUALIZER_DIR
= $(QUANTUM_DIR
)/visualizer
283 VISUALIZER_PATH
= $(QUANTUM_PATH
)/visualizer
284 include $(VISUALIZER_PATH
)/visualizer.mk
287 OUTPUTS
:= $(KEYMAP_OUTPUT
) $(KEYBOARD_OUTPUT
)
288 $(KEYMAP_OUTPUT
)_SRC
:= $(SRC
)
289 $(KEYMAP_OUTPUT
)_DEFS
:= $(OPT_DEFS
) $(GFXDEFS
) -DQMK_KEYBOARD
=\"$(KEYBOARD
)\" -DQMK_KEYMAP
=\"$(KEYMAP
)\"
290 $(KEYMAP_OUTPUT
)_INC
:= $(VPATH
) $(EXTRAINCDIRS
)
291 $(KEYMAP_OUTPUT
)_CONFIG
:= $(CONFIG_H
)
292 $(KEYBOARD_OUTPUT
)_SRC
:= $(CHIBISRC
) $(GFXSRC
)
293 $(KEYBOARD_OUTPUT
)_DEFS
:= $(PROJECT_DEFS
) $(GFXDEFS
)
294 $(KEYBOARD_OUTPUT
)_INC
:= $(PROJECT_INC
) $(GFXINC
)
295 $(KEYBOARD_OUTPUT
)_CONFIG
:= $(PROJECT_CONFIG
)
300 # Change the build target to build a HEX file or a library.
302 #build: elf hex eep lss sym
306 include $(TMK_PATH
)/rules.mk