summaryrefslogtreecommitdiffstats
path: root/tinybeeper/Makefile
blob: be5d93577a982bb06239d66a62f2477961be82d9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
# The architecture configuration
ARCH		= attiny13
AVRDUDE_ARCH	= t13
AVRDUDE_SPEED	= 1
PROGRAMMER	= avrisp2
PROGPORT	= usb
TOPRAMMER_ID	= attiny13dip8

# The toolchain definitions
CC		= avr-gcc
OBJCOPY		= avr-objcopy
SIZE		= avr-size
READELF		= avr-readelf
SPARSE		= sparse
TOPRAMMER	= toprammer
AVRDUDE		= avrdude

DEBUG		= 0		# Debug build:  make DEBUG=1

V		= @		# Verbose build:  make V=1
C		= 0		# Sparsechecker build:  make C=1
Q		= $(V:1=)
QUIET_CC	= $(Q:@=@echo '     CC       '$@;)$(CC)
QUIET_DEPEND	= $(Q:@=@echo '     DEPEND   '$@;)$(CC)
QUIET_OBJCOPY	= $(Q:@=@echo '     OBJCOPY  '$@;)$(OBJCOPY)
QUIET_SIZE	= $(Q:@=@echo '     SIZE     '$@;)$(SIZE)
QUIET_READELF	= $(Q:@=@echo '     READELF  '$@;)$(READELF)
ifeq ($(C),1)
QUIET_SPARSE	= $(Q:@=@echo '     SPARSE   '$@;)$(SPARSE)
else
QUIET_SPARSE	= @/bin/true
endif

CFLAGS		= -mmcu=$(ARCH) -std=gnu99 -g0 -Os -Wall -DDEBUG=$(DEBUG) \
		  "-Dinline=inline __attribute__((__always_inline__))"

SPARSEFLAGS	= $(CFLAGS) -I "/usr/lib/avr/include" -D__AVR_ARCH__=4 \
		  -D__AVR_ATmega8__=1 -D__ATTR_PROGMEM__="" -Dsignal=dllexport \
		  -Dexternally_visible=dllexport


# The fuse bits
LFUSE	= F1
HFUSE	= FF

F_CPU	= 4800000

SRCS	= main.c
NAME	= tinybeeper
ELF	= $(NAME).elf
BIN	= $(NAME).bin
HEX	= $(NAME).hex
EEP	= $(NAME).eep.hex

CFLAGS	+= -DF_CPU=$(F_CPU)

.SUFFIXES:
.PHONY: all avrdude install_flash install_eeprom install reset writefuse clean distclean
.DEFAULT_GOAL := all

DEPS = $(sort $(patsubst %.c,dep/%.d,$(1)))
OBJS = $(sort $(patsubst %.c,obj/%.o,$(1)))

# Generate dependencies
$(call DEPS,$(SRCS)): dep/%.d: %.c 
	@mkdir -p $(dir $@)
	$(QUIET_DEPEND) -o $@.tmp -MM -MG -MT "$@ $(patsubst dep/%.d,obj/%.o,$@)" $(CFLAGS) $< && mv -f $@.tmp $@

-include $(call DEPS,$(SRCS))

# Generate object files
$(call OBJS,$(SRCS)): obj/%.o:
	@mkdir -p $(dir $@)
	$(QUIET_SPARSE) $(SPARSEFLAGS) $<
	$(QUIET_CC) -o $@ -c $(CFLAGS) $<

all: $(HEX)

%.s: %.c
	$(QUIET_CC) $(CFLAGS) -S $*.c

$(ELF): $(call OBJS,$(SRCS))
	$(QUIET_CC) $(CFLAGS) -o $(ELF) $(call OBJS,$(SRCS)) $(LDFLAGS)

$(HEX): $(ELF)
	$(QUIET_OBJCOPY) -R.eeprom -O ihex $(ELF) $(HEX)
	$(QUIET_OBJCOPY) -R.eeprom -O binary $(ELF) $(BIN)
	$(QUIET_OBJCOPY) -j.eeprom --set-section-flags=.eeprom="alloc,load" \
			 --change-section-lma .eeprom=0 -O ihex $(ELF) $(EEP)
	$(QUIET_SIZE) $(ELF)
	$(QUIET_READELF) -S $(ELF) | egrep '(Name|text|eeprom|data|bss)'

avrdude:
	$(AVRDUDE) -B $(AVRDUDE_SPEED) -p $(AVRDUDE_ARCH) \
	 -c $(PROGRAMMER) -P $(PROGPORT) -t

install_flash:
	$(AVRDUDE) -B $(AVRDUDE_SPEED) -p $(AVRDUDE_ARCH) \
	 -c $(PROGRAMMER) -P $(PROGPORT) -U flash:w:$(HEX)

install_eeprom:
	$(AVRDUDE) -B $(AVRDUDE_SPEED) -p $(AVRDUDE_ARCH) \
	 -c $(PROGRAMMER) -P $(PROGPORT) -U eeprom:w:$(EEP)

install: all install_flash install_eeprom

toprammer_install: all
	$(TOPRAMMER) -c $(TOPRAMMER_ID) -x
	echo "0x0000: $(LFUSE)$(HFUSE)" | $(TOPRAMMER) -c $(TOPRAMMER_ID) -I hex -F -
	$(TOPRAMMER) -c $(TOPRAMMER_ID) -I ihex -P $(HEX)

# Reset the microcontroller through avrdude
reset:
	$(AVRDUDE) -B $(AVRDUDE_SPEED) -p $(AVRDUDE_ARCH) \
	 -c $(PROGRAMMER) -P $(PROGPORT) \
	 -U signature:r:/dev/null:i -q -q

writefuse:
	$(AVRDUDE) -B $(AVRDUDE_SPEED) -p $(AVRDUDE_ARCH) \
	 -c $(PROGRAMMER) -P $(PROGPORT) -q -q \
	 -U lfuse:w:0x$(LFUSE):m \
	 -U hfuse:w:0x$(HFUSE):m

clean:
	-rm -Rf dep obj *~ *.pyc $(ELF)

distclean: clean
	-rm -f *.s $(HEX) $(BIN) $(EEP)
bues.ch cgit interface