d3195b2ab5109cbac3761ea865e1a43722bf1864
[pub/lufa.git] / LUFA / Build / DMBS / DMBS / hid.mk
1 #
2 # DMBS Build System
3 # Released into the public domain.
4 #
5 # dean [at] fourwalledcubicle [dot] com
6 # www.fourwalledcubicle.com
7 #
8
9 DMBS_BUILD_MODULES += HID
10 DMBS_BUILD_TARGETS += hid hid-ee teensy teensy-ee
11 DMBS_BUILD_MANDATORY_VARS += MCU TARGET
12 DMBS_BUILD_OPTIONAL_VARS +=
13 DMBS_BUILD_PROVIDED_VARS +=
14 DMBS_BUILD_PROVIDED_MACROS +=
15
16 # Import the CORE module of DMBS
17 DMBS_MODULE_PATH := $(patsubst %/,%,$(dir $(lastword $(MAKEFILE_LIST))))
18 include $(DMBS_MODULE_PATH)/core.mk
19
20 # Sanity-check values of mandatory user-supplied variables
21 $(foreach MANDATORY_VAR, $(DMBS_BUILD_MANDATORY_VARS), $(call ERROR_IF_UNSET, $(MANDATORY_VAR)))
22 $(call ERROR_IF_EMPTY, MCU)
23 $(call ERROR_IF_EMPTY, TARGET)
24
25 # Output Messages
26 MSG_HID_BOOTLOADER_CMD := ' [HID] :'
27 MSG_OBJCPY_CMD := ' [OBJCPY] :'
28 MSG_MAKE_CMD := ' [MAKE] :'
29
30 # Set MAKE variable if the environment does not already define it
31 MAKE ?= make
32
33 # Programs in the target FLASH memory using the HID_BOOTLOADER_CLI tool
34 hid: $(TARGET).hex $(MAKEFILE_LIST)
35 @echo $(MSG_HID_BOOTLOADER_CMD) Programming FLASH with hid_bootloader_cli using \"$<\"
36 hid_bootloader_cli -mmcu=$(MCU) -v $<
37
38 # Programs in the target EEPROM memory using the HID_BOOTLOADER_CLI tool (note: clears target FLASH memory)
39 hid-ee: $(TARGET).eep $(MAKEFILE_LIST)
40 @echo $(MSG_OBJCPY_CMD) Converting \"$<\" to a binary file \"InputEEData.bin\"
41 avr-objcopy -I ihex -O binary $< $(DMBS_MODULE_PATH)/HID_EEPROM_Loader/InputEEData.bin
42 @echo $(MSG_MAKE_CMD) Making EEPROM loader application for \"$<\"
43 $(MAKE) -C $(DMBS_MODULE_PATH)/HID_EEPROM_Loader/ MCU=$(MCU) clean hid
44
45 # Programs in the target FLASH memory using the TEENSY_BOOTLOADER_CLI tool
46 teensy: $(TARGET).hex $(MAKEFILE_LIST)
47 @echo $(MSG_HID_BOOTLOADER_CMD) Programming FLASH with teensy_loader_cli using \"$<\"
48 teensy_loader_cli -mmcu=$(MCU) -v $<
49
50 # Programs in the target EEPROM memory using the TEENSY_BOOTLOADER_CLI tool (note: clears target FLASH memory)
51 teensy-ee: $(TARGET).hex $(MAKEFILE_LIST)
52 @echo $(MSG_OBJCPY_CMD) Converting \"$<\" to a binary file \"InputEEData.bin\"
53 avr-objcopy -I ihex -O binary $< $(DMBS_MODULE_PATH)/HID_EEPROM_Loader/InputEEData.bin
54 @echo $(MSG_MAKE_CMD) Making EEPROM loader application for \"$<\"
55 $(MAKE) -s -C $(DMBS_MODULE_PATH)/HID_EEPROM_Loader/ MCU=$(MCU) clean teensy
56
57 # Phony build targets for this module
58 .PHONY: $(DMBS_BUILD_TARGETS)