Commit mthomas changes to GCC and port those changes to IAR
[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 += -gdwarf-2 -std=gnu99 -Os -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums -ffunction-sections\r
17 CFLAGS += -fno-inline-small-functions -fno-split-wide-types\r
18 CFLAGS += -Wall -Wstrict-prototypes -Wundef -Wa,-adhlns=./$(*F).lst\r
19 CFLAGS += -MMD -MP -MF dep/$(@F).d  \r
20 CFLAGS += -DNIMH\r
21 \r
22 ## Assembly specific flags\r
23 ASMFLAGS = $(COMMON)\r
24 ASMFLAGS += $(CFLAGS)\r
25 ASMFLAGS += -x assembler-with-cpp -Wa,-gdwarf2\r
26 \r
27 ## Linker flags\r
28 LDFLAGS = $(COMMON)\r
29 LDFLAGS +=  -Wl,-Map=$(PROJECT).map,--cref -Wl,-gc-sections -Wl,-relax\r
30 \r
31 \r
32 ## Intel Hex file production flags\r
33 HEX_FLASH_FLAGS = -R .eeprom\r
34 \r
35 HEX_EEPROM_FLAGS = -j .eeprom\r
36 HEX_EEPROM_FLAGS += --set-section-flags=.eeprom="alloc,load"\r
37 HEX_EEPROM_FLAGS += --change-section-lma .eeprom=0 --no-change-warnings\r
38 \r
39 \r
40 ## Libraries\r
41 LIBS = -lm \r
42 \r
43 ## Objects that must be built in order to link\r
44 OBJECTS = ADC.o battery.o chargefunc.o main.o menu.o NIMHcharge.o OWI.o PWM.o statefunc.o time.o USI.o \r
45 \r
46 ## Objects explicitly added by the user\r
47 LINKONLYOBJECTS = \r
48 \r
49 ## Build\r
50 all: $(TARGET) $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss size\r
51 \r
52 ## Compile\r
53 ADC.o: ../ADC.c\r
54         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
55 \r
56 battery.o: ../battery.c\r
57         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
58 \r
59 chargefunc.o: ../chargefunc.c\r
60         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
61 \r
62 main.o: ../main.c\r
63         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
64 \r
65 menu.o: ../menu.c\r
66         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
67 \r
68 NIMHcharge.o: ../NIMHcharge.c\r
69         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
70 \r
71 OWI.o: ../OWI.c\r
72         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
73 \r
74 PWM.o: ../PWM.c\r
75         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
76 \r
77 statefunc.o: ../statefunc.c\r
78         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
79 \r
80 time.o: ../time.c\r
81         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
82 \r
83 USI.o: ../USI.c\r
84         $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
85 \r
86 ##Link\r
87 $(TARGET): $(OBJECTS)\r
88          $(CC) $(LDFLAGS) $(OBJECTS) $(LINKONLYOBJECTS) $(LIBDIRS) $(LIBS) -o $(TARGET)\r
89 \r
90 %.hex: $(TARGET)\r
91         avr-objcopy -O ihex $(HEX_FLASH_FLAGS)  $< $@\r
92 \r
93 %.eep: $(TARGET)\r
94         -avr-objcopy $(HEX_EEPROM_FLAGS) -O ihex $< $@ || exit 0\r
95 \r
96 %.lss: $(TARGET)\r
97         avr-objdump -h -S $< > $@\r
98 \r
99 size: ${TARGET}\r
100         @echo\r
101         @avr-size -C --mcu=${MCU} ${TARGET}\r
102 \r
103 ## Clean target\r
104 .PHONY: clean\r
105 clean:\r
106         -rm -rf $(OBJECTS) $(PROJECT).elf dep $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss $(PROJECT).map *.lst\r
107 \r
108 \r
109 ## Other dependencies\r
110 -include $(shell mkdir dep 2>/dev/null) $(wildcard dep/*)\r