You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
155 lines
3.6 KiB
Makefile
155 lines
3.6 KiB
Makefile
MCU = atxmega32a4
|
|
TARGET = main
|
|
AVRDUDE_PROGRAMMER = atmelice_pdi
|
|
FCPU=2000000UL
|
|
|
|
BUILDDIR=build
|
|
|
|
OPT = s
|
|
SRC = $(shell find src -name '*.c')
|
|
#SRC = main.c
|
|
|
|
FORMAT = ihex
|
|
|
|
# List any extra directories to look for include files here.
|
|
# Each directory must be seperated by a space.
|
|
EXTRAINCDIRS = inc
|
|
|
|
#### Flags ####
|
|
CFLAGS = -mmcu=$(MCU) -I. \
|
|
-g -ggdb -O$(OPT) \
|
|
-funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums \
|
|
-Wall -Wstrict-prototypes \
|
|
-Wa,-adhlns=$(<:src/%.c=$(BUILDDIR)/%.lst) \
|
|
-DF_CPU=$(FCPU)\
|
|
$(patsubst %,-I%,$(EXTRAINCDIRS))\
|
|
-std=gnu99 \
|
|
-fno-builtin
|
|
|
|
LDFLAGS = -Wl,-Map=$(BUILDDIR)/$(TARGET).map,--cref
|
|
# Minimalistic printf version
|
|
#LDFLAGS += -Wl,-u,vfprintf -lprintf_min
|
|
|
|
# Floating point printf version (requires -lm below)
|
|
#LDFLAGS += -Wl,-u,vfprintf -lprintf_flt
|
|
|
|
# -lm = math library
|
|
LDFLAGS += -lm
|
|
#LDFLAGS += -nostdlib
|
|
|
|
AVRDUDE_FLAGS = -p $(MCU) -c $(AVRDUDE_PROGRAMMER) -U flash:w:$(BUILDDIR)/$(TARGET).hex
|
|
|
|
#### Define programs and commands. ####
|
|
CC = avr-gcc
|
|
|
|
OBJCOPY = avr-objcopy
|
|
OBJDUMP = avr-objdump
|
|
SIZE = avr-size
|
|
AVRDUDE = avrdude
|
|
|
|
|
|
REMOVE = rm -f
|
|
COPY = cp
|
|
|
|
# Define all object files.
|
|
OBJ = $(SRC:src/%.c=$(BUILDDIR)/%.o)
|
|
|
|
# Define all listing files.
|
|
LST = $(SRC:src/%.c=$(BUILDDIR)/%.lst)
|
|
|
|
# Default target: make program!
|
|
all: $(TARGET).elf
|
|
# $(BUILDDIR)/$(TARGET).lss $(BUILDDIR)/$(TARGET).sym
|
|
# $(AVRDUDE) $(AVRDUDE_FLAGS) $(AVRDUDE_WRITE_FLASH) $(AVRDUDE_WRITE_EEPROM)
|
|
|
|
# Program the device.
|
|
program: $(BUILDDIR)/$(TARGET).hex $(BUILDDIR)/$(TARGET).eep
|
|
$(AVRDUDE) $(AVRDUDE_FLAGS)
|
|
|
|
|
|
# Create final output files (.hex, .eep) from ELF output file.
|
|
$(BUILDDIR)/%.hex: %.elf
|
|
@echo
|
|
@echo "creating ihex"
|
|
$(OBJCOPY) -O $(FORMAT) -R .eeprom $< $@
|
|
|
|
$(BUILDDIR)/%.eep: %.elf
|
|
@echo
|
|
@echo "eeprom"
|
|
-$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" \
|
|
--change-section-lma .eeprom=0 -O $(FORMAT) $< $@
|
|
|
|
# Create extended listing file from ELF output file.
|
|
$(BUILDDIR)/%.lss: %.elf
|
|
@echo
|
|
@echo "listing"
|
|
$(OBJDUMP) -h -S $< > $@
|
|
|
|
# Create a symbol table from ELF output file.
|
|
$(BUILDDIR)/%.sym: %.elf
|
|
@echo
|
|
@echo "symbol table"
|
|
avr-nm -n $< > $@
|
|
|
|
|
|
|
|
# Link: create ELF output file from object files.
|
|
#.SECONDARY : $(BUILDDIR)/$(TARGET).elf
|
|
#.PRECIOUS : $(OBJ)
|
|
$(TARGET).elf: $(OBJ)
|
|
@echo
|
|
@echo "linking: " $(OBJ)
|
|
mkdir -p build
|
|
$(CC) $(CFLAGS) $(OBJ) --output $@ $(LDFLAGS)
|
|
|
|
|
|
# Compile: create object files from C source files.
|
|
$(BUILDDIR)/%.o : src/%.c
|
|
@echo
|
|
@echo "compiling" $<
|
|
mkdir -p build
|
|
$(CC) -c $(CFLAGS) $< -o $@
|
|
|
|
|
|
# Target: clean project.
|
|
clean:
|
|
@echo
|
|
@echo "cleaning"
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).hex
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).eep
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).obj
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).cof
|
|
$(REMOVE) $(TARGET).elf
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).map
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).obj
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).a90
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).sym
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).lnk
|
|
$(REMOVE) $(BUILDDIR)/$(TARGET).lss
|
|
$(REMOVE) $(OBJ)
|
|
$(REMOVE) $(LST)
|
|
$(REMOVE) $(SRC:src/%.c=$(BUILDDIR)/%.s)
|
|
$(REMOVE) $(SRC:src/%.c=$(BUILDDIR)/%.d)
|
|
$(REMOVE) $(BUILDDIR)/*~
|
|
|
|
# Automatically generate C source code dependencies.
|
|
# (Code originally taken from the GNU make user manual and modified
|
|
# (See README.txt Credits).)
|
|
#
|
|
# Note that this will work with sh (bash) and sed that is shipped with WinAVR
|
|
# (see the SHELL variable defined above).
|
|
# This may not work with other shells or other seds.
|
|
#
|
|
$(BUILDDIR)/%.d: %.c
|
|
set -e; $(CC) -MM $(CFLAGS) $< \
|
|
| sed 's,\(.*\)\.o[ :]*,\1.o \1.d : ,g' > $@; \
|
|
[ -s $@ ] || rm -f $@
|
|
|
|
|
|
# Remove the '-' if you want to see the dependency files generated.
|
|
-include $(SRC:.c=.d)
|
|
|
|
# Listing of phony targets.
|
|
.PHONY : all clean program
|
|
|