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
179 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_unicode_common.c
180 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_ucis.c
183 ifeq ($(strip $(UNICODEMAP_ENABLE
)), yes
)
184 OPT_DEFS
+= -DUNICODEMAP_ENABLE
185 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_unicode_common.c
186 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_unicodemap.c
189 ifeq ($(strip $(UNICODE_ENABLE
)), yes
)
190 OPT_DEFS
+= -DUNICODE_ENABLE
191 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_unicode_common.c
192 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_unicode.c
195 ifeq ($(strip $(RGBLIGHT_ENABLE
)), yes
)
196 OPT_DEFS
+= -DRGBLIGHT_ENABLE
197 SRC
+= $(QUANTUM_DIR
)/light_ws2812.c
198 SRC
+= $(QUANTUM_DIR
)/rgblight.c
200 LED_BREATHING_TABLE
= yes
203 ifeq ($(strip $(TAP_DANCE_ENABLE
)), yes
)
204 OPT_DEFS
+= -DTAP_DANCE_ENABLE
205 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_tap_dance.c
208 ifeq ($(strip $(PRINTING_ENABLE
)), yes
)
209 OPT_DEFS
+= -DPRINTING_ENABLE
210 SRC
+= $(QUANTUM_DIR
)/process_keycode
/process_printer.c
211 SRC
+= $(TMK_DIR
)/protocol
/serial_uart.c
214 ifeq ($(strip $(SERIAL_LINK_ENABLE
)), yes
)
215 SRC
+= $(patsubst $(QUANTUM_PATH
)/%,%,$(SERIAL_SRC
))
216 OPT_DEFS
+= $(SERIAL_DEFS
)
217 VAPTH
+= $(SERIAL_PATH
)
220 ifneq ($(strip $(VARIABLE_TRACE
)),)
221 SRC
+= $(QUANTUM_DIR
)/variable_trace.c
222 OPT_DEFS
+= -DNUM_TRACED_VARIABLES
=$(strip $(VARIABLE_TRACE
))
223 ifneq ($(strip $(MAX_VARIABLE_TRACE_SIZE
)),)
224 OPT_DEFS
+= -DMAX_VARIABLE_TRACE_SIZE
=$(strip $(MAX_VARIABLE_TRACE_SIZE
))
228 ifeq ($(strip $(LCD_ENABLE
)), yes
)
232 ifeq ($(strip $(LED_ENABLE
)), yes
)
236 ifeq ($(strip $(CIE1931_CURVE
)), yes
)
237 OPT_DEFS
+= -DUSE_CIE1931_CURVE
241 ifeq ($(strip $(LED_BREATHING_TABLE
)), yes
)
242 OPT_DEFS
+= -DUSE_LED_BREATHING_TABLE
246 ifeq ($(strip $(LED_TABLES
)), yes
)
247 SRC
+= $(QUANTUM_DIR
)/led_tables.c
250 # Optimize size but this may cause error "relocation truncated to fit"
251 #EXTRALDFLAGS = -Wl,--relax
254 VPATH
+= $(KEYMAP_PATH
)
255 ifneq ($(SUBPROJECT
),)
256 VPATH
+= $(SUBPROJECT_PATH
)
258 VPATH
+= $(KEYBOARD_PATH
)
259 VPATH
+= $(COMMON_VPATH
)
261 include $(TMK_PATH
)/protocol.mk
263 include $(TMK_PATH
)/common.mk
264 SRC
+= $(TMK_COMMON_SRC
)
265 OPT_DEFS
+= $(TMK_COMMON_DEFS
)
266 EXTRALDFLAGS
+= $(TMK_COMMON_LDFLAGS
)
268 ifeq ($(PLATFORM
),AVR
)
269 ifeq ($(strip $(PROTOCOL
)), VUSB
)
270 include $(TMK_PATH
)/protocol
/vusb.mk
272 include $(TMK_PATH
)/protocol
/lufa.mk
274 include $(TMK_PATH
)/avr.mk
277 ifeq ($(strip $(VISUALIZER_ENABLE
)), yes
)
278 VISUALIZER_DIR
= $(QUANTUM_DIR
)/visualizer
279 VISUALIZER_PATH
= $(QUANTUM_PATH
)/visualizer
280 include $(VISUALIZER_PATH
)/visualizer.mk
283 OUTPUTS
:= $(KEYMAP_OUTPUT
) $(KEYBOARD_OUTPUT
)
284 $(KEYMAP_OUTPUT
)_SRC
:= $(SRC
)
285 $(KEYMAP_OUTPUT
)_DEFS
:= $(OPT_DEFS
) $(GFXDEFS
) -DQMK_KEYBOARD
=\"$(KEYBOARD
)\" -DQMK_KEYMAP
=\"$(KEYMAP
)\"
286 $(KEYMAP_OUTPUT
)_INC
:= $(VPATH
) $(EXTRAINCDIRS
)
287 $(KEYMAP_OUTPUT
)_CONFIG
:= $(CONFIG_H
)
288 $(KEYBOARD_OUTPUT
)_SRC
:= $(CHIBISRC
) $(GFXSRC
)
289 $(KEYBOARD_OUTPUT
)_DEFS
:= $(PROJECT_DEFS
) $(GFXDEFS
)
290 $(KEYBOARD_OUTPUT
)_INC
:= $(PROJECT_INC
) $(GFXINC
)
291 $(KEYBOARD_OUTPUT
)_CONFIG
:= $(PROJECT_CONFIG
)
296 # Change the build target to build a HEX file or a library.
298 #build: elf hex eep lss sym
302 include $(TMK_PATH
)/rules.mk