############################################################################### # Makefile for the project MasterAT91 ############################################################################### ## General Flags PROJECT = MasterAT91 MCU = arm7tdmi TARGET = AT91 CC = arm-gcc.exe SRC = ../../../src DRV = ../../../drivers/AT91 INC = ../../../include ## Options common to compile, link and assembly rules COMMON = -mmcu=$(MCU) ## Compile options common for all C compilation units. CFLAGS = $(COMMON) CFLAGS += -Wall -gdwarf-2 -Os -fsigned-char -fpack-struct #CFLAGS += -MD -MP -MT $(*F).o -MF dep/$(@F).d ## Assembly specific flags ASMFLAGS = $(COMMON) ASMFLAGS += $(CFLAGS) ASMFLAGS += -x assembler-with-cpp -Wa,-gdwarf2 ## Linker flags LDFLAGS = $(COMMON) LDFLAGS += -Wl,-Map=$(PROJECT).map ## Intel Hex file production flags HEX_FLASH_FLAGS = -R .eeprom HEX_EEPROM_FLAGS = -j .eeprom HEX_EEPROM_FLAGS += --set-section-flags=.eeprom="alloc,load" HEX_EEPROM_FLAGS += --change-section-lma .eeprom=0 --no-change-warnings ## Include Directories INCLUDES = -I$(INC) -I$(INC)/AT91 ## Objects that must be built in order to link OBJECTS = $(DRV)/can_AT91.o\ $(DRV)/timer_AT91.o\ $(SRC)/dcf.o\ $(SRC)/timer.o\ $(SRC)/emcy.o\ $(SRC)/lifegrd.o\ $(SRC)/lss.o\ $(SRC)/nmtMaster.o\ $(SRC)/nmtSlave.o\ $(SRC)/objacces.o\ $(SRC)/pdo.o\ $(SRC)/sdo.o\ $(SRC)/states.o\ $(SRC)/sync.o\ ObjDict.o\ interrupt_timer.o\ main.o ## Build all: $(PROJECT).elf $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss size ## Compile %.o: %.c # @echo " " @echo "---------------------------------------------------------------------------" @echo "**Compiling $< -> $@" # @echo "*********************************************" $(CC) $(INCLUDES) $(CFLAGS) -c $< # $(CC) $(INCLUDES) $(CFLAGS) -c -o $@ $< ##Link $(PROJECT).elf: $(OBJECTS) # @echo " " @echo "---------------------------------------------------------------------------" @echo "**Linking : $@" # @echo "*********************************************" $(CC) $(LDFLAGS) $(LIBDIRS) $(LIBS) $(^F) -o $@ %.hex: $(PROJECT).elf arm-elf-objcopy.exe -O ihex $(HEX_FLASH_FLAGS) $< $@ %.eep: $(PROJECT).elf -arm-elf-objcopy.exe $(HEX_EEPROM_FLAGS) -O ihex $< $@ || exit 0 %.lss: $(PROJECT).elf arm-elf-objdump.exe -h -S $< > $@ size: $(PROJECT).elf @echo @arm-elf-size -C --mcu=${MCU} $(PROJECT).elf ## Clean target .PHONY: clean clean: -rm -rf *.o $(PROJECT).elf dep/* $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss $(PROJECT).map ## Other dependencies -include $(shell mkdir dep 2>/dev/null) $(wildcard dep/*)