2016-08-26 17:58:42 +02:00
|
|
|
|
|
|
|
TARGET = xmc4300-ecat-slave
|
|
|
|
|
|
|
|
DEVICE = XMC4300
|
|
|
|
VARIANT = F100x256
|
|
|
|
|
|
|
|
EC_SII = sii_eeprom.bin
|
|
|
|
|
2016-08-26 19:11:40 +02:00
|
|
|
XMC_LIB = ./XMC_Peripheral_Library
|
|
|
|
SOES_DIR = ../../soes
|
|
|
|
|
|
|
|
|
2016-08-26 17:58:42 +02:00
|
|
|
SRC = \
|
|
|
|
main.c \
|
|
|
|
objectlist.c \
|
2019-04-04 17:48:16 +02:00
|
|
|
$(SOES_DIR)/ecat_slv.c \
|
2016-08-26 19:11:40 +02:00
|
|
|
$(SOES_DIR)/esc.c \
|
|
|
|
$(SOES_DIR)/esc_coe.c \
|
|
|
|
$(SOES_DIR)/esc_eep.c \
|
|
|
|
$(SOES_DIR)/hal/xmc4/esc_hw.c \
|
|
|
|
$(SOES_DIR)/hal/xmc4/esc_hw_eep.c \
|
|
|
|
$(XMC_LIB)/XMCLib/src/xmc_gpio.c \
|
|
|
|
$(XMC_LIB)/XMCLib/src/xmc4_gpio.c \
|
|
|
|
$(XMC_LIB)/XMCLib/src/xmc4_scu.c \
|
|
|
|
$(XMC_LIB)/XMCLib/src/xmc_ecat.c \
|
|
|
|
$(XMC_LIB)/XMCLib/src/xmc4_flash.c \
|
|
|
|
$(XMC_LIB)/XMCLib/src/xmc_fce.c \
|
|
|
|
$(XMC_LIB)/Newlib/syscalls.c \
|
|
|
|
$(XMC_LIB)/CMSIS/Infineon/XMC4300_series/Source/system_XMC4300.c \
|
2016-08-26 17:58:42 +02:00
|
|
|
|
|
|
|
ASRC = \
|
2016-08-26 19:11:40 +02:00
|
|
|
$(XMC_LIB)/CMSIS/Infineon/XMC4300_series/Source/GCC/startup_XMC4300.S \
|
2016-08-26 17:58:42 +02:00
|
|
|
|
|
|
|
BINS = \
|
|
|
|
$(EC_SII)\
|
|
|
|
|
2016-08-26 19:11:40 +02:00
|
|
|
LINKER_SCRIPT = $(XMC_LIB)/CMSIS/Infineon/XMC4300_series/Source/GCC/XMC4300x256.ld
|
2016-08-26 17:58:42 +02:00
|
|
|
|
|
|
|
# JLink options
|
|
|
|
JLINK_SPEED = 1000
|
|
|
|
JLINK_IFACE = swd
|
|
|
|
|
|
|
|
# Define all object files.
|
|
|
|
OBJ = $(SRC:.c=.o) $(ASRC:.S=.o) $(BINS:.bin=.o)
|
|
|
|
|
|
|
|
# Define all listing files.
|
|
|
|
LST = $(ASRC:.S=.lst) $(SRC:.c=.lst)
|
|
|
|
|
|
|
|
# Define all dependency files.
|
|
|
|
DEP = $(ASRC:.S=.d) $(SRC:.c=.d)
|
|
|
|
|
|
|
|
CPPFLAGS = -D$(DEVICE)_$(VARIANT)
|
|
|
|
CPPFLAGS += -MMD -MP -MF $(@:.o=.d) -MT $(@)
|
|
|
|
|
2016-08-26 19:11:40 +02:00
|
|
|
CPPFLAGS += -I./$(XMC_LIB)/XMCLib/inc
|
|
|
|
CPPFLAGS += -I./$(XMC_LIB)/CMSIS/Include
|
|
|
|
CPPFLAGS += -I./$(XMC_LIB)/CMSIS/Infineon/$(DEVICE)_series/Include
|
2016-08-26 17:58:42 +02:00
|
|
|
CPPFLAGS += -I.
|
2016-08-26 19:11:40 +02:00
|
|
|
CPPFLAGS += -I$(SOES_DIR)
|
|
|
|
CPPFLAGS += -I$(SOES_DIR)/hal/xmc4
|
|
|
|
CPPFLAGS += -I$(SOES_DIR)/include/sys/gcc
|
2016-08-26 17:58:42 +02:00
|
|
|
|
|
|
|
ARCHFLAGS = -mfloat-abi=softfp -mcpu=cortex-m4 -mfpu=fpv4-sp-d16 -mthumb
|
|
|
|
|
|
|
|
OBJFLAGS = -Wall -fmessage-length=0 -Wa,-adhlns=$(@:.o=.lst) $(ARCHFLAGS)
|
|
|
|
|
|
|
|
CFLAGS = $(CPPFLAGS) $(OBJFLAGS) -Os -ffunction-sections -fdata-sections -std=gnu99 -pipe
|
|
|
|
ASFLAGS = -x assembler-with-cpp $(CPPFLAGS) $(OBJFLAGS)
|
|
|
|
|
|
|
|
LDFLAGS = -T$(LINKER_SCRIPT) -nostartfiles -Xlinker --gc-sections
|
|
|
|
LDFLAGS += -specs=nano.specs -specs=nosys.specs
|
|
|
|
LDFLAGS += -Wl,-Map,$(TARGET).map
|
|
|
|
LDFLAGS += $(ARCHFLAGS)
|
|
|
|
|
|
|
|
# Define programs and commands.
|
|
|
|
SHELL = sh
|
|
|
|
REMOVE = rm -f
|
|
|
|
CC = arm-none-eabi-gcc
|
|
|
|
OBJCOPY = arm-none-eabi-objcopy
|
|
|
|
OBJDUMP = arm-none-eabi-objdump
|
|
|
|
SIZE = arm-none-eabi-size
|
|
|
|
JLINK = JLinkExe
|
|
|
|
|
|
|
|
# Define Messages
|
|
|
|
# English
|
|
|
|
MSG_SIZE = Size:
|
|
|
|
MSG_FLASH_FILE = Creating load file for Flash:
|
|
|
|
MSG_FLASH = Programming target flash memory:
|
|
|
|
MSG_FLASH_ERASE = Erasing target flash memory:
|
|
|
|
MSG_EXTENDED_LISTING = Creating Extended Listing:
|
|
|
|
MSG_LINKING = Linking:
|
|
|
|
MSG_COMPILING = Compiling:
|
|
|
|
MSG_ASSEMBLING = Assembling:
|
|
|
|
MSG_OBJCOPY = ObjCopy:
|
|
|
|
MSG_CLEANING = Cleaning project:
|
|
|
|
|
|
|
|
# Default target.
|
|
|
|
all: $(TARGET).hex size
|
|
|
|
|
|
|
|
# Compile: create object files from C source files.
|
|
|
|
%.o : %.c
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_COMPILING) $<
|
|
|
|
$(CC) -c $(CFLAGS) -o $@ $<
|
|
|
|
|
|
|
|
# Assemble: create object files from assembler source files.
|
|
|
|
%.o : %.S
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_ASSEMBLING) $<
|
|
|
|
$(CC) -c $(ASFLAGS) -o $@ $<
|
|
|
|
|
|
|
|
# ObjCopy: create object files from binary files.
|
|
|
|
%.o : %.bin
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_OBJCOPY) $<
|
|
|
|
$(OBJCOPY) -I binary -O elf32-littlearm -B arm $< $@
|
|
|
|
|
|
|
|
# Link: create ELF output file from object files.
|
|
|
|
$(TARGET).elf: $(OBJ)
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_LINKING) $@
|
|
|
|
$(CC) $(LDFLAGS) -o $@ $(OBJ)
|
|
|
|
|
|
|
|
# Create final output file from ELF output file.
|
|
|
|
$(TARGET).hex: $(TARGET).elf
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_FLASH_FILE) $@
|
|
|
|
$(OBJCOPY) -O ihex $< $@
|
|
|
|
|
|
|
|
# Create extended listing file from ELF output file.
|
|
|
|
$(TARGET).lss: $(TARGET).elf
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_EXTENDED_LISTING) $@
|
|
|
|
$(OBJDUMP) -h -S $(TARGET).elf > $(TARGET).lss
|
|
|
|
|
|
|
|
# Display size of file.
|
|
|
|
size: $(TARGET).elf
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_SIZE)
|
|
|
|
$(SIZE) --format=berkeley $(TARGET).elf
|
|
|
|
@echo
|
|
|
|
|
|
|
|
# Flash the target device.
|
|
|
|
flash: $(TARGET).hex
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_FLASH)
|
|
|
|
echo -e "device $(DEVICE)-$(VARIANT)\nspeed $(JLINK_SPEED)\nsi $(JLINK_IFACE)\nloadfile $(TARGET).hex\ng\nqc\n" | $(JLINK)
|
|
|
|
|
|
|
|
# Erase the target flash
|
|
|
|
erase:
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_FLASH_ERASE)
|
|
|
|
echo -e "device $(DEVICE)-$(VARIANT)\nspeed $(JLINK_SPEED)\nsi $(JLINK_IFACE)\nerase\nqc\n" | $(JLINK)
|
|
|
|
|
|
|
|
# Target: clean project.
|
|
|
|
clean:
|
|
|
|
@echo
|
|
|
|
@echo $(MSG_CLEANING)
|
|
|
|
$(REMOVE) $(TARGET).map
|
|
|
|
$(REMOVE) $(TARGET).elf
|
|
|
|
$(REMOVE) $(TARGET).hex
|
|
|
|
$(REMOVE) $(TARGET).lss
|
|
|
|
$(REMOVE) $(OBJ)
|
|
|
|
$(REMOVE) $(LST)
|
|
|
|
$(REMOVE) $(DEP)
|
|
|
|
|
|
|
|
# Include the dependency files.
|
|
|
|
-include $(DEP)
|
|
|
|
|
|
|
|
# Listing of phony targets.
|
|
|
|
.PHONY: all clean size flash erase
|
|
|
|
|