initial version of assembly port of serial_lcd.
[avr_serial_lcd.git] / gcc_asm / Makefile
1 ###############################################################################\r
2 # Makefile for the serial_lcd C version for GCC\r
3 \r
4 ## General Flags\r
5 PROJECT = serial_lcd\r
6 MCU = attiny2313\r
7 TARGET = $(PROJECT).elf\r
8 CC = avr-gcc\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 += -DF_CPU=14745600UL -Os\r
16 \r
17 ## Assembly specific flags\r
18 ASMFLAGS = $(COMMON) -D__ASSEMBLER__\r
19 ASMFLAGS += -DF_CPU=14745600UL -Os\r
20 ASMFLAGS += -Wa,-gstabs\r
21 \r
22 ## Linker flags\r
23 LDFLAGS = $(COMMON)\r
24 LDFLAGS +=  -Wl,-Map=$(PROJECT).map,--cref\r
25 \r
26 \r
27 ## Intel Hex file production flags\r
28 HEX_FLASH_FLAGS = -R .eeprom\r
29 HEX_EEPROM_FLAGS = -j .eeprom\r
30 HEX_EEPROM_FLAGS += --set-section-flags=.eeprom="alloc,load"\r
31 HEX_EEPROM_FLAGS += --change-section-lma .eeprom=0 --no-change-warnings\r
32 \r
33 \r
34 ## Objects that must be built in order to link\r
35 OBJECTS = $(PROJECT).o \r
36 \r
37 ## Objects explicitly added by the user\r
38 LINKONLYOBJECTS = \r
39 \r
40 ## Build\r
41 all: $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss size \r
42 \r
43 ## Compile\r
44 $(PROJECT).o: ../$(PROJECT).S\r
45         $(CC) $(ASMFLAGS) -c $< -o $(PROJECT).o\r
46 \r
47 ##Link\r
48 $(TARGET): $(OBJECTS)\r
49          $(CC) $(LDFLAGS) $(OBJECTS) $(LINKONLYOBJECTS) $(LIBDIRS) $(LIBS) -o $(TARGET)\r
50 \r
51 $(PROJECT).hex: $(TARGET)\r
52         avr-objcopy -O ihex $(HEX_FLASH_FLAGS)  $< $@\r
53 \r
54 $(PROJECT).eep: $(TARGET)\r
55         -avr-objcopy $(HEX_EEPROM_FLAGS) -O ihex $< $@ || exit 0\r
56 \r
57 $(PROJECT).lss: $(TARGET)\r
58         avr-objdump -h -S $< > $@\r
59 \r
60 .PHONY: size\r
61 size: ${TARGET}\r
62         @echo $(TARGET) size\r
63         @avr-size -C --mcu=${MCU} ${TARGET}\r
64 \r
65 ## Clean target\r
66 .PHONY: distclean\r
67 distclean: clean\r
68         @rm -rf $(PROJECT).hex $(PROJECT).lss $(PROJECT).map $(PROJECT).lst \r
69 \r
70 .PHONY: clean\r
71 clean:\r
72         @rm -rf $(OBJECTS) $(TARGET) $(PROJECT).eep\r
73 \r
74 \r