fix case name, improve syntax for linker option
[avr_bc100.git] / BaseTinyFirmware / GCC / avr463 / Makefile
1  ###############################################################################\r
2 # Makefile for the project avr463\r
3 ###############################################################################\r
4 \r
5 ## General Flags\r
6 PROJECT = avr463\r
7 MCU = attiny861\r
8 TARGET = $(PROJECT).elf\r
9 CC = avr-gcc\r
10 \r
11 ## Options common to compile, link and assembly rules\r
12 COMMON = -mmcu=$(MCU)\r
13 \r
14 ## Compile options common for all C compilation units.\r
15 CFLAGS = $(COMMON)\r
16 CFLAGS += -Wall -gdwarf-2 -std=gnu99 -Os -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums -DNIMH\r
17 CFLAGS += -MD -MP -MT $(*F).o -MF dep/$(@F).d \r
18 \r
19 ## Assembly specific flags\r
20 ASMFLAGS = $(COMMON)\r
21 ASMFLAGS += $(CFLAGS)\r
22 ASMFLAGS += -x assembler-with-cpp -Wa,-gdwarf2\r
23 \r
24 ## Linker flags\r
25 LDFLAGS = $(COMMON)\r
26 LDFLAGS +=  -Wl,-Map=$(PROJECT).map -Wl,--relax\r
27 \r
28 \r
29 ## Intel Hex file production flags\r
30 HEX_FLASH_FLAGS = -R .eeprom\r
31 \r
32 HEX_EEPROM_FLAGS = -j .eeprom\r
33 HEX_EEPROM_FLAGS += --set-section-flags=.eeprom="alloc,load"\r
34 HEX_EEPROM_FLAGS += --change-section-lma .eeprom=0 --no-change-warnings\r
35 \r
36 \r
37 ## Libraries\r
38 LIBS = -lm \r
39 \r
40 ## Objects that must be built in order to link\r
41 OBJECTS = ADC.o battery.o chargefunc.o main.o menu.o NIMHcharge.o OWI.o PWM.o statefunc.o time.o USI.o \r
42 \r
43 ## Objects explicitly added by the user\r
44 LINKONLYOBJECTS = \r
45 \r
46 ## Build\r
47 all: $(TARGET) $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss size\r
48 \r
49 ## Compile\r
50 ADC.o: ../ADC.c\r
51         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
52 \r
53 battery.o: ../battery.c\r
54         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
55 \r
56 chargefunc.o: ../chargefunc.c\r
57         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
58 \r
59 main.o: ../main.c\r
60         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
61 \r
62 menu.o: ../menu.c\r
63         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
64 \r
65 NIMHcharge.o: ../NIMHcharge.c\r
66         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
67 \r
68 OWI.o: ../OWI.c\r
69         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
70 \r
71 PWM.o: ../PWM.c\r
72         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
73 \r
74 statefunc.o: ../statefunc.c\r
75         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
76 \r
77 time.o: ../time.c\r
78         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
79 \r
80 USI.o: ../USI.c\r
81         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
82 \r
83 ##Link\r
84 $(TARGET): $(OBJECTS)\r
85          $(CC) $(LDFLAGS) $(OBJECTS) $(LINKONLYOBJECTS) $(LIBDIRS) $(LIBS) -o $(TARGET)\r
86 \r
87 %.hex: $(TARGET)\r
88         avr-objcopy -O ihex $(HEX_FLASH_FLAGS)  $< $@\r
89 \r
90 %.eep: $(TARGET)\r
91         -avr-objcopy $(HEX_EEPROM_FLAGS) -O ihex $< $@ || exit 0\r
92 \r
93 %.lss: $(TARGET)\r
94         avr-objdump -h -S $< > $@\r
95 \r
96 size: ${TARGET}\r
97         @echo\r
98         @avr-size -C --mcu=${MCU} ${TARGET}\r
99 \r
100 ## Clean target\r
101 .PHONY: clean\r
102 clean:\r
103         -rm -rf $(OBJECTS) $(PROJECT).elf dep $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss $(PROJECT).map\r
104 \r
105 \r
106 ## Other dependencies\r
107 -include $(shell mkdir dep 2>/dev/null) $(wildcard dep/*)\r