summaryrefslogtreecommitdiff
path: root/dice/firmware/Makefile
diff options
context:
space:
mode:
Diffstat (limited to 'dice/firmware/Makefile')
-rw-r--r--dice/firmware/Makefile49
1 files changed, 49 insertions, 0 deletions
diff --git a/dice/firmware/Makefile b/dice/firmware/Makefile
new file mode 100644
index 0000000..80cffce
--- /dev/null
+++ b/dice/firmware/Makefile
@@ -0,0 +1,49 @@
+MAKEFLAGS += --no-builtin-rules --no-builtin-variables
+
+# This variable can be overwritten to show executed commands
+Q ?= @
+
+# TODO use CC instead of GCC but at the moment --no-builtin-variables seems to
+# break somehow detection of not defined variable.
+TARGET ?= avr-
+GCC ?= $(TARGET)gcc
+OBJCOPY ?= $(TARGET)objcopy
+AVRDUDE ?= avrdude
+
+MCU ?= attiny85
+F_CPU ?= 16000000L
+CFLAGS ?= -Os -mmcu=$(MCU) -DF_CPU=$(F_CPU)
+LDFLAGS ?= -Os -mmcu=$(MCU)
+
+#####################
+SRC := main.c
+#####################
+OBJ := $(patsubst %.c,%.o,$(SRC))
+
+.PHONY: all
+all: firmware.hex
+
+$(OBJ): %.o: %.c
+ @echo "CC $@"
+ $(Q)$(GCC) -c $(CFLAGS) $< -o $@
+
+firmware.elf: $(OBJ)
+ @echo "LD $@"
+ $(Q)$(GCC) $(LDFLAGS) $< -o $@
+
+firmware.hex: firmware.elf
+ @echo "OBJCOPY $@"
+ $(Q)$(OBJCOPY) -O ihex -R .eeprom $< $@
+
+
+.PHONY: install
+install: firmware.hex
+ @echo "AVRDUDE $@"
+ $(Q)$(AVRDUDE) -p$(MCU) -cusbasp -D -Uflash:w:$<:a
+
+# TODO probably configure fuses
+
+.PHONY: clean
+clean:
+ rm -f $(OBJ)
+ rm -f firmware.elf firmware.hex