Subversion Repositories Projects

Rev

Rev 734 | Rev 757 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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