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))
34 KEYBOARD_PATH := keyboards/$(KEYBOARD)
35 KEYBOARD_C := $(KEYBOARD_PATH)/$(KEYBOARD).c
37 ifneq ("$(wildcard $(KEYBOARD_C))","")
38 include $(KEYBOARD_PATH)/rules.mk
40 $(error "$(KEYBOARD_C)" does not exist)
42 OPT_DEFS += -DKEYBOARD_$(KEYBOARD)
44 ifneq ($(SUBPROJECT),)
45 SUBPROJECT_PATH := keyboards/$(KEYBOARD)/$(SUBPROJECT)
46 SUBPROJECT_C := $(SUBPROJECT_PATH)/$(SUBPROJECT).c
47 ifneq ("$(wildcard $(SUBPROJECT_C))","")
48 OPT_DEFS += -DSUBPROJECT_$(SUBPROJECT)
49 include $(SUBPROJECT_PATH)/rules.mk
51 $(error "$(SUBPROJECT_PATH)/$(SUBPROJECT).c" does not exist)
55 # We can assume a ChibiOS target When MCU_FAMILY is defined, since it's not used for LUFA
62 ifeq ($(PLATFORM),CHIBIOS)
63 include $(TMK_PATH)/protocol/chibios.mk
64 include $(TMK_PATH)/chibios.mk
66 ifneq ("$(wildcard $(SUBPROJECT_PATH)/bootloader_defs.h)","")
67 OPT_DEFS += -include $(SUBPROJECT_PATH)/bootloader_defs.h
68 else ifneq ("$(wildcard $(SUBPROJECT_PATH)/boards/$(BOARD)/bootloader_defs.h)","")
69 OPT_DEFS += -include $(SUBPROJECT_PATH)/boards/$(BOARD)/bootloader_defs.h
70 else ifneq ("$(wildcard $(KEYBOARD_PATH)/bootloader_defs.h)","")
71 OPT_DEFS += -include $(KEYBOARD_PATH)/bootloader_defs.h
72 else ifneq ("$(wildcard $(KEYBOARD_PATH)/boards/$(BOARD)/bootloader_defs.h)","")
73 OPT_DEFS += -include $(KEYBOARD_PATH)/boards/$(BOARD)/bootloader_defs.h
77 CONFIG_H = $(KEYBOARD_PATH)/config.h
78 ifneq ($(SUBPROJECT),)
79 ifneq ("$(wildcard $(SUBPROJECT_C))","")
80 CONFIG_H = $(SUBPROJECT_PATH)/config.h
84 # Save the defines and includes here, so we don't include any keymap specific ones
85 PROJECT_DEFS := $(OPT_DEFS)
86 PROJECT_INC := $(VPATH) $(EXTRAINCDIRS) $(SUBPROJECT_PATH) $(KEYBOARD_PATH)
87 PROJECT_CONFIG := $(CONFIG_H)
89 MAIN_KEYMAP_PATH := $(KEYBOARD_PATH)/keymaps/$(KEYMAP)
90 MAIN_KEYMAP_C := $(MAIN_KEYMAP_PATH)/keymap.c
91 SUBPROJ_KEYMAP_PATH := $(SUBPROJECT_PATH)/keymaps/$(KEYMAP)
92 SUBPROJ_KEYMAP_C := $(SUBPROJ_KEYMAP_PATH)/keymap.c
93 ifneq ("$(wildcard $(SUBPROJ_KEYMAP_C))","")
94 -include $(SUBPROJ_KEYMAP_PATH)/Makefile
95 KEYMAP_C := $(SUBPROJ_KEYMAP_C)
96 KEYMAP_PATH := $(SUBPROJ_KEYMAP_PATH)
97 else ifneq ("$(wildcard $(MAIN_KEYMAP_C))","")
98 -include $(MAIN_KEYMAP_PATH)/Makefile
99 KEYMAP_C := $(MAIN_KEYMAP_C)
100 KEYMAP_PATH := $(MAIN_KEYMAP_PATH)
101 else ifneq ($(LAYOUTS),)
102 include build_layout.mk
104 $(error Could not find keymap)
105 # this state should never be reached
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) \
123 ifneq ($(SUBPROJECT),)
124 SRC += $(SUBPROJECT_C)
127 # Optimize size but this may cause error "relocation truncated to fit"
128 #EXTRALDFLAGS = -Wl,--relax
131 VPATH += $(KEYMAP_PATH)
132 ifneq ($(SUBPROJECT),)
133 VPATH += $(SUBPROJECT_PATH)
135 VPATH += $(KEYBOARD_PATH)
136 VPATH += $(COMMON_VPATH)
138 include common_features.mk
139 include $(TMK_PATH)/protocol.mk
140 include $(TMK_PATH)/common.mk
142 SRC += $(TMK_COMMON_SRC)
143 OPT_DEFS += $(TMK_COMMON_DEFS)
144 EXTRALDFLAGS += $(TMK_COMMON_LDFLAGS)
146 ifeq ($(PLATFORM),AVR)
147 ifeq ($(strip $(PROTOCOL)), VUSB)
148 include $(TMK_PATH)/protocol/vusb.mk
150 include $(TMK_PATH)/protocol/lufa.mk
152 include $(TMK_PATH)/avr.mk
155 ifeq ($(strip $(VISUALIZER_ENABLE)), yes)
156 VISUALIZER_DIR = $(QUANTUM_DIR)/visualizer
157 VISUALIZER_PATH = $(QUANTUM_PATH)/visualizer
158 include $(VISUALIZER_PATH)/visualizer.mk
161 OUTPUTS := $(KEYMAP_OUTPUT) $(KEYBOARD_OUTPUT)
162 $(KEYMAP_OUTPUT)_SRC := $(SRC)
163 $(KEYMAP_OUTPUT)_DEFS := $(OPT_DEFS) $(GFXDEFS) \
164 -DQMK_KEYBOARD=\"$(KEYBOARD)\" -DQMK_KEYBOARD_H=\"$(KEYBOARD).h\" -DQMK_KEYBOARD_CONFIG_H=\"$(KEYBOARD_PATH)/config.h\" \
165 -DQMK_KEYMAP=\"$(KEYMAP)\" -DQMK_KEYMAP_H=\"$(KEYMAP).h\" -DQMK_KEYMAP_CONFIG_H=\"$(KEYMAP_PATH)/config.h\" \
166 -DQMK_SUBPROJECT=\"$(SUBPROJECT)\" -DQMK_SUBPROJECT_H=\"$(SUBPROJECT).h\" -DQMK_SUBPROJECT_CONFIG_H=\"$(SUBPROJECT_PATH)/config.h\"
167 $(KEYMAP_OUTPUT)_INC := $(VPATH) $(EXTRAINCDIRS)
168 $(KEYMAP_OUTPUT)_CONFIG := $(CONFIG_H)
169 $(KEYBOARD_OUTPUT)_SRC := $(CHIBISRC) $(GFXSRC)
170 $(KEYBOARD_OUTPUT)_DEFS := $(PROJECT_DEFS) $(GFXDEFS)
171 $(KEYBOARD_OUTPUT)_INC := $(PROJECT_INC) $(GFXINC)
172 $(KEYBOARD_OUTPUT)_CONFIG := $(PROJECT_CONFIG)
177 # Change the build target to build a HEX file or a library.
179 #build: elf hex eep lss sym
183 include $(TMK_PATH)/rules.mk