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
|
# The architecture configuration
ARCH = atmega8
AVRDUDE_ARCH = m8
AVRDUDE = avrdude
AVRDUDE_SPEED = 1
PROGRAMMER = avrisp2
PROGPORT = usb
# The toolchain definitions
CC = avr-gcc
OBJCOPY = avr-objcopy
SIZE = avr-size
SPARSE = sparse
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)
ifeq ($(C),1)
QUIET_SPARSE = $(Q:@=@echo ' SPARSE '$@;)$(SPARSE)
else
QUIET_SPARSE = @/bin/true
endif
CFLAGS = -mmcu=$(ARCH) -std=c99 -g0 -Os -Wall \
"-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 = 0x40
HFUSE = 0xD9
SRCS = main.c
NAME = 4094sniffer
BIN = $(NAME).bin
HEX = $(NAME).hex
EEP = $(NAME).eep.hex
.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
%.o: %.c
$(QUIET_SPARSE) $(SPARSEFLAGS) $<
$(QUIET_CC) -o $@ -c $(CFLAGS) $<
$(BIN): $(call OBJS,$(SRCS))
$(QUIET_CC) $(CFLAGS) -o $(BIN) $(call OBJS,$(SRCS)) $(LDFLAGS)
$(HEX): $(BIN)
$(QUIET_OBJCOPY) -R.eeprom -O ihex $(BIN) $(HEX)
# $(QUIET_OBJCOPY) -j.eeprom --set-section-flags=.eeprom="alloc,load" \
# --change-section-lma .eeprom=0 -O ihex $(BIN) $(EEP)
$(QUIET_SIZE) $(BIN)
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
# 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 100 -p $(AVRDUDE_ARCH) \
-c $(PROGRAMMER) -P $(PROGPORT) -q -q \
-U lfuse:w:$(LFUSE):m \
-U hfuse:w:$(HFUSE):m
clean:
-rm -Rf obj dep *~ $(BIN)
distclean: clean
-rm -f *.s $(HEX) $(EEP)
|