2008-03-30 Kevin Rosenberg <kevin@rosenberg.net>
[avr_serial_lcd.git] / gcc_cpp / Makefile
1 ###############################################################################\r
2 # Makefile for the serial_lcd CPP version for GCC\r
3 \r
4 ## General Flags\r
5 PROJECT = serial_lcd_cpp\r
6 MCU = attiny2313\r
7 TARGET = $(PROJECT).elf\r
8 CC = avr-g++\r
9 \r
10 ## Options common to compile, link and assembly rules\r
11 COMMON = -mmcu=$(MCU)\r
12 \r
13 ## Compile options common for all C compilation units.\r
14 CFLAGS = $(COMMON)\r
15 CFLAGS += -gdwarf-2  -DF_CPU=14745600UL -Os \r
16 CFLAGS +=-funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums\r
17 CFLAGS += -Wall -Wundef -Wa,-adhlns=./$(*F).lst\r
18 CFLAGS += -MMD -MP -MT $(*F).o -MF .dep/$(@F).d \r
19 \r
20 ## Assembly specific flags\r
21 ASMFLAGS = $(COMMON)\r
22 ASMFLAGS += $(CFLAGS)\r
23 ASMFLAGS += -x assembler-with-cpp -Wa,-gdwarf2\r
24 \r
25 ## Linker flags\r
26 LDFLAGS = $(COMMON)\r
27 LDFLAGS +=  -Wl,-Map=$(PROJECT).map,--cref -Wl,-gc-sections -Wl,-relax\r
28 \r
29 \r
30 ## Intel Hex file production flags\r
31 HEX_FLASH_FLAGS = -R .eeprom\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 ## Include Directories\r
38 INCLUDES = -I.\r
39 \r
40 ## Objects that must be built in order to link\r
41 OBJECTS = $(PROJECT).o \r
42 \r
43 ## Objects explicitly added by the user\r
44 LINKONLYOBJECTS = \r
45 \r
46 ## Build\r
47 all: $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss size \r
48 \r
49 ## Compile\r
50 $(PROJECT).o: ../$(PROJECT).cpp\r
51         $(CC) $(INCLUDES) $(CFLAGS) -c  $< -o $(PROJECT).o\r
52 \r
53 ##Link\r
54 $(TARGET): $(OBJECTS)\r
55          $(CC) $(LDFLAGS) $(OBJECTS) $(LINKONLYOBJECTS) $(LIBDIRS) $(LIBS) -o $(TARGET)\r
56 \r
57 $(PROJECT).hex: $(TARGET)\r
58         avr-objcopy -O ihex $(HEX_FLASH_FLAGS)  $< $@\r
59 \r
60 $(PROJECT).eep: $(TARGET)\r
61         -avr-objcopy $(HEX_EEPROM_FLAGS) -O ihex $< $@ || exit 0\r
62 \r
63 $(PROJECT).lss: $(TARGET)\r
64         avr-objdump -h -S $< > $@\r
65 \r
66 .PHONY: size\r
67 \r
68 size: ${TARGET}\r
69         @echo $(TARGET) size\r
70         @avr-size -C --mcu=${MCU} ${TARGET}\r
71 \r
72 ## Clean target\r
73 .PHONY: distclean\r
74 distclean: clean\r
75         @rm -rf $(PROJECT).hex $(PROJECT).lss $(PROJECT).map $(PROJECT).lst\r
76 \r
77 .PHONY: clean\r
78 clean:\r
79         @rm -rf $(OBJECTS) $(TARGET) $(PROJECT).eep .dep\r
80 \r
81 ## Other dependencies\r
82 -include $(shell mkdir .dep 2>/dev/null) $(wildcard .dep/*)\r
83 \r