Subversion Repositories svnkaklik

Rev

Details | Last modification | View Log

Rev Author Line No. Line
567 kaklik 1
###############################################################################
2
# Makefile for the project main
3
###############################################################################
4
 
5
## General Flags
6
PROJECT = main
7
MCU = atmega168
8
TARGET = main.elf
9
CC = avr-gcc.exe
10
 
11
## Options common to compile, link and assembly rules
12
COMMON = -mmcu=$(MCU)
13
 
14
## Compile options common for all C compilation units.
15
CFLAGS = $(COMMON)
16
CFLAGS += -Wall -gdwarf-2 -std=gnu99   -DF_CPU=14318180UL -Os -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums
17
CFLAGS += -MD -MP -MT $(*F).o -MF dep/$(@F).d 
18
 
19
## Assembly specific flags
20
ASMFLAGS = $(COMMON)
21
ASMFLAGS += $(CFLAGS)
22
ASMFLAGS += -x assembler-with-cpp -Wa,-gdwarf2
23
 
24
## Linker flags
25
LDFLAGS = $(COMMON)
26
LDFLAGS +=  -Wl,-Map=main.map
27
 
28
 
29
## Intel Hex file production flags
30
HEX_FLASH_FLAGS = -R .eeprom
31
 
32
HEX_EEPROM_FLAGS = -j .eeprom
33
HEX_EEPROM_FLAGS += --set-section-flags=.eeprom="alloc,load"
34
HEX_EEPROM_FLAGS += --change-section-lma .eeprom=0 --no-change-warnings
35
 
36
 
37
## Objects that must be built in order to link
38
OBJECTS = main.o uart.o 
39
 
40
## Objects explicitly added by the user
41
LINKONLYOBJECTS = 
42
 
43
## Build
44
all: $(TARGET) main.hex main.eep main.lss size
45
 
46
## Compile
47
main.o: ../main.c
48
	$(CC) $(INCLUDES) $(CFLAGS) -c  $<
49
 
50
uart.o: ../uart.c
51
	$(CC) $(INCLUDES) $(CFLAGS) -c  $<
52
 
53
##Link
54
$(TARGET): $(OBJECTS)
55
	 $(CC) $(LDFLAGS) $(OBJECTS) $(LINKONLYOBJECTS) $(LIBDIRS) $(LIBS) -o $(TARGET)
56
 
57
%.hex: $(TARGET)
58
	avr-objcopy -O ihex $(HEX_FLASH_FLAGS)  $< $@
59
 
60
%.eep: $(TARGET)
61
	-avr-objcopy $(HEX_EEPROM_FLAGS) -O ihex $< $@ || exit 0
62
 
63
%.lss: $(TARGET)
64
	avr-objdump -h -S $< > $@
65
 
66
size: ${TARGET}
67
	@echo
68
	@avr-size -C --mcu=${MCU} ${TARGET}
69
 
70
## Clean target
71
.PHONY: clean
72
clean:
73
	-rm -rf $(OBJECTS) main.elf dep/* main.hex main.eep main.lss main.map
74
 
75
 
76
## Other dependencies
77
-include $(shell mkdir dep 2>/dev/null) $(wildcard dep/*)
78