Commit | Line | Data |
---|---|---|
86706de0 FS |
1 | ifndef VERBOSE |
2 | .SILENT: | |
3 | endif | |
4 | ||
5 | .DEFAULT_GOAL := all | |
6 | ||
27a673f5 | 7 | include common.mk |
8f164031 FS |
8 | |
9 | ifneq ($(SUBPROJECT),) | |
10 | TARGET ?= $(KEYBOARD)_$(SUBPROJECT)_$(KEYMAP) | |
11 | KEYBOARD_OUTPUT := $(BUILD_DIR)/obj_$(KEYBOARD)_$(SUBPROJECT) | |
12 | else | |
13 | TARGET ?= $(KEYBOARD)_$(KEYMAP) | |
14 | KEYBOARD_OUTPUT := $(BUILD_DIR)/obj_$(KEYBOARD) | |
15 | endif | |
16 | ||
17 | # Force expansion | |
18 | TARGET := $(TARGET) | |
19 | ||
86706de0 | 20 | |
86706de0 FS |
21 | MASTER ?= left |
22 | ifdef master | |
23 | MASTER = $(master) | |
24 | endif | |
25 | ||
c692fd1d FS |
26 | ifeq ($(MASTER),right) |
27 | OPT_DEFS += -DMASTER_IS_ON_RIGHT | |
28 | else | |
29 | ifneq ($(MASTER),left) | |
30 | $(error MASTER does not have a valid value(left/right)) | |
31 | endif | |
32 | endif | |
33 | ||
34 | ||
35 | ||
67b294ca FS |
36 | KEYBOARD_PATH := keyboards/$(KEYBOARD) |
37 | KEYBOARD_C := $(KEYBOARD_PATH)/$(KEYBOARD).c | |
86706de0 | 38 | |
67b294ca FS |
39 | ifneq ("$(wildcard $(KEYBOARD_C))","") |
40 | include $(KEYBOARD_PATH)/rules.mk | |
86706de0 | 41 | else |
67b294ca FS |
42 | $(error "$(KEYBOARD_C)" does not exist) |
43 | endif | |
44 | ||
45 | ||
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 | |
52 | else | |
53 | $(error "$(SUBPROJECT_PATH)/$(SUBPROJECT).c" does not exist) | |
54 | endif | |
55 | endif | |
56 | ||
33fbd3be FS |
57 | # We can assume a ChibiOS target When MCU_FAMILY is defined, since it's not used for LUFA |
58 | ifdef MCU_FAMILY | |
59 | PLATFORM=CHIBIOS | |
60 | else | |
61 | PLATFORM=AVR | |
62 | endif | |
63 | ||
64 | ifeq ($(PLATFORM),CHIBIOS) | |
65 | include $(TMK_PATH)/protocol/chibios.mk | |
66 | include $(TMK_PATH)/chibios.mk | |
67 | OPT_OS = chibios | |
3442e216 FS |
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 | |
76 | endif | |
33fbd3be FS |
77 | endif |
78 | ||
9028a412 FS |
79 | CONFIG_H = $(KEYBOARD_PATH)/config.h |
80 | ifneq ($(SUBPROJECT),) | |
81 | ifneq ("$(wildcard $(SUBPROJECT_C))","") | |
82 | CONFIG_H = $(SUBPROJECT_PATH)/config.h | |
83 | endif | |
84 | endif | |
85 | ||
33fbd3be | 86 | # Save the defines and includes here, so we don't include any keymap specific ones |
3aac4e95 | 87 | PROJECT_DEFS := $(OPT_DEFS) |
33fbd3be | 88 | PROJECT_INC := $(VPATH) $(EXTRAINCDIRS) $(SUBPROJECT_PATH) $(KEYBOARD_PATH) |
9028a412 | 89 | PROJECT_CONFIG := $(CONFIG_H) |
3aac4e95 | 90 | |
67b294ca FS |
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) | |
103 | else | |
104 | $(error "$(MAIN_KEYMAP_C)/keymap.c" does not exist) | |
86706de0 FS |
105 | endif |
106 | ||
86706de0 | 107 | |
86706de0 FS |
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! | |
3aac4e95 | 111 | KEYMAP_OUTPUT := $(BUILD_DIR)/obj_$(TARGET) |
86706de0 FS |
112 | |
113 | ||
86706de0 FS |
114 | ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","") |
115 | CONFIG_H = $(KEYMAP_PATH)/config.h | |
86706de0 FS |
116 | endif |
117 | ||
118 | # # project specific files | |
67b294ca FS |
119 | SRC += $(KEYBOARD_C) \ |
120 | $(KEYMAP_C) \ | |
86706de0 FS |
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 | |
125 | ||
67b294ca FS |
126 | ifneq ($(SUBPROJECT),) |
127 | SRC += $(SUBPROJECT_C) | |
86706de0 FS |
128 | endif |
129 | ||
130 | ifndef CUSTOM_MATRIX | |
131 | SRC += $(QUANTUM_DIR)/matrix.c | |
132 | endif | |
133 | ||
7edac212 JH |
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 | |
139 | MIDI_ENABLE=yes | |
140 | endif | |
141 | ||
86706de0 FS |
142 | ifeq ($(strip $(MIDI_ENABLE)), yes) |
143 | OPT_DEFS += -DMIDI_ENABLE | |
144 | SRC += $(QUANTUM_DIR)/process_keycode/process_midi.c | |
145 | endif | |
146 | ||
eac8fa79 OP |
147 | ifeq ($(strip $(COMBO_ENABLE)), yes) |
148 | OPT_DEFS += -DCOMBO_ENABLE | |
149 | SRC += $(QUANTUM_DIR)/process_keycode/process_combo.c | |
150 | endif | |
151 | ||
2e3834ed FS |
152 | ifeq ($(strip $(VIRTSER_ENABLE)), yes) |
153 | OPT_DEFS += -DVIRTSER_ENABLE | |
154 | endif | |
155 | ||
86706de0 FS |
156 | ifeq ($(strip $(AUDIO_ENABLE)), yes) |
157 | OPT_DEFS += -DAUDIO_ENABLE | |
158 | SRC += $(QUANTUM_DIR)/process_keycode/process_music.c | |
159 | SRC += $(QUANTUM_DIR)/audio/audio.c | |
160 | SRC += $(QUANTUM_DIR)/audio/voices.c | |
161 | SRC += $(QUANTUM_DIR)/audio/luts.c | |
162 | endif | |
163 | ||
2f0395ce GN |
164 | ifeq ($(strip $(UCIS_ENABLE)), yes) |
165 | OPT_DEFS += -DUCIS_ENABLE | |
166 | UNICODE_ENABLE = yes | |
167 | endif | |
168 | ||
5b2e455d PIN |
169 | ifeq ($(strip $(UNICODEMAP_ENABLE)), yes) |
170 | OPT_DEFS += -DUNICODEMAP_ENABLE | |
171 | UNICODE_ENABLE = yes | |
172 | endif | |
173 | ||
86706de0 FS |
174 | ifeq ($(strip $(UNICODE_ENABLE)), yes) |
175 | OPT_DEFS += -DUNICODE_ENABLE | |
176 | SRC += $(QUANTUM_DIR)/process_keycode/process_unicode.c | |
177 | endif | |
178 | ||
179 | ifeq ($(strip $(RGBLIGHT_ENABLE)), yes) | |
180 | OPT_DEFS += -DRGBLIGHT_ENABLE | |
181 | SRC += $(QUANTUM_DIR)/light_ws2812.c | |
182 | SRC += $(QUANTUM_DIR)/rgblight.c | |
183 | endif | |
184 | ||
185 | ifeq ($(strip $(TAP_DANCE_ENABLE)), yes) | |
186 | OPT_DEFS += -DTAP_DANCE_ENABLE | |
187 | SRC += $(QUANTUM_DIR)/process_keycode/process_tap_dance.c | |
188 | endif | |
189 | ||
5f91fb41 JH |
190 | ifeq ($(strip $(PRINTING_ENABLE)), yes) |
191 | OPT_DEFS += -DPRINTING_ENABLE | |
192 | SRC += $(QUANTUM_DIR)/process_keycode/process_printer.c | |
193 | SRC += $(TMK_DIR)/protocol/serial_uart.c | |
194 | endif | |
195 | ||
86706de0 | 196 | ifeq ($(strip $(SERIAL_LINK_ENABLE)), yes) |
86706de0 | 197 | SRC += $(patsubst $(QUANTUM_PATH)/%,%,$(SERIAL_SRC)) |
0a114601 | 198 | OPT_DEFS += $(SERIAL_DEFS) |
86706de0 FS |
199 | VAPTH += $(SERIAL_PATH) |
200 | endif | |
201 | ||
a377017c FS |
202 | ifneq ($(strip $(VARIABLE_TRACE)),) |
203 | SRC += $(QUANTUM_DIR)/variable_trace.c | |
204 | OPT_DEFS += -DNUM_TRACED_VARIABLES=$(strip $(VARIABLE_TRACE)) | |
205 | ifneq ($(strip $(MAX_VARIABLE_TRACE_SIZE)),) | |
206 | OPT_DEFS += -DMAX_VARIABLE_TRACE_SIZE=$(strip $(MAX_VARIABLE_TRACE_SIZE)) | |
207 | endif | |
208 | endif | |
f519b94b | 209 | |
86706de0 FS |
210 | # Optimize size but this may cause error "relocation truncated to fit" |
211 | #EXTRALDFLAGS = -Wl,--relax | |
212 | ||
213 | # Search Path | |
214 | VPATH += $(KEYMAP_PATH) | |
67b294ca | 215 | ifneq ($(SUBPROJECT),) |
86706de0 FS |
216 | VPATH += $(SUBPROJECT_PATH) |
217 | endif | |
218 | VPATH += $(KEYBOARD_PATH) | |
c692fd1d | 219 | VPATH += $(COMMON_VPATH) |
86706de0 | 220 | |
3be13d1f | 221 | include $(TMK_PATH)/protocol.mk |
86706de0 | 222 | |
86706de0 | 223 | include $(TMK_PATH)/common.mk |
c692fd1d FS |
224 | SRC += $(TMK_COMMON_SRC) |
225 | OPT_DEFS += $(TMK_COMMON_DEFS) | |
226 | EXTRALDFLAGS += $(TMK_COMMON_LDFLAGS) | |
227 | ||
86706de0 | 228 | ifeq ($(PLATFORM),AVR) |
f7462aaa LR |
229 | ifeq ($(strip $(PROTOCOL)), VUSB) |
230 | include $(TMK_PATH)/protocol/vusb.mk | |
231 | else | |
86706de0 | 232 | include $(TMK_PATH)/protocol/lufa.mk |
f7462aaa | 233 | endif |
86706de0 | 234 | include $(TMK_PATH)/avr.mk |
86706de0 FS |
235 | endif |
236 | ||
237 | ifeq ($(strip $(VISUALIZER_ENABLE)), yes) | |
238 | VISUALIZER_DIR = $(QUANTUM_DIR)/visualizer | |
239 | VISUALIZER_PATH = $(QUANTUM_PATH)/visualizer | |
240 | include $(VISUALIZER_PATH)/visualizer.mk | |
241 | endif | |
242 | ||
3aac4e95 FS |
243 | OUTPUTS := $(KEYMAP_OUTPUT) $(KEYBOARD_OUTPUT) |
244 | $(KEYMAP_OUTPUT)_SRC := $(SRC) | |
245 | $(KEYMAP_OUTPUT)_DEFS := $(OPT_DEFS) -DQMK_KEYBOARD=\"$(KEYBOARD)\" -DQMK_KEYMAP=\"$(KEYMAP)\" | |
c692fd1d | 246 | $(KEYMAP_OUTPUT)_INC := $(VPATH) $(EXTRAINCDIRS) |
9028a412 | 247 | $(KEYMAP_OUTPUT)_CONFIG := $(CONFIG_H) |
3aac4e95 FS |
248 | $(KEYBOARD_OUTPUT)_SRC := $(CHIBISRC) |
249 | $(KEYBOARD_OUTPUT)_DEFS := $(PROJECT_DEFS) | |
33fbd3be | 250 | $(KEYBOARD_OUTPUT)_INC := $(PROJECT_INC) |
9028a412 | 251 | $(KEYBOARD_OUTPUT)_CONFIG := $(PROJECT_CONFIG) |
3aac4e95 | 252 | |
8a9aac6e FS |
253 | # Default target. |
254 | all: build sizeafter | |
255 | ||
256 | # Change the build target to build a HEX file or a library. | |
257 | build: elf hex | |
258 | #build: elf hex eep lss sym | |
259 | #build: lib | |
260 | ||
3aac4e95 | 261 | |
86706de0 FS |
262 | include $(TMK_PATH)/rules.mk |
263 |