2017-07-26 14:59:20 +01:00
|
|
|
VPATH = $(ROOT)/firmware
|
|
|
|
|
|
|
|
XILINX ?= /opt/Xilinx/14.7
|
|
|
|
|
2018-02-15 13:05:49 +00:00
|
|
|
PATH := $(PATH):${XILINX}/ISE_DS/ISE/bin/lin64:${PAPILIO}/linux64
|
2017-07-26 14:59:20 +01:00
|
|
|
SHELL := env PATH=$(PATH) /bin/bash
|
|
|
|
|
2017-07-29 19:55:27 +01:00
|
|
|
# Frequency of the AVR CPU
|
|
|
|
F_CPU ?= 15855484
|
|
|
|
|
2019-11-11 11:16:42 +00:00
|
|
|
# Default Baud Rate of serial interface
|
|
|
|
# Note: F_CPU / 16 / BAUD need to be close to an integer
|
|
|
|
BAUD ?= 57600
|
|
|
|
|
2017-07-26 14:59:20 +01:00
|
|
|
# Path of the back anotated block memory map file
|
|
|
|
BMM_FILE ?= memory_bd.bmm
|
|
|
|
|
|
|
|
# AVR dev environment
|
|
|
|
MCU=atmega103
|
|
|
|
CC=avr-gcc
|
|
|
|
OBJCOPY=avr-objcopy
|
|
|
|
|
|
|
|
PROG = avr_progmem
|
|
|
|
|
2019-11-11 11:16:42 +00:00
|
|
|
CFLAGS=$(CPU_CFLAGS) -DF_CPU=${F_CPU}UL -DBAUD=${BAUD} -mmcu=$(MCU) -Wall -Os -mcall-prologues
|
2017-07-26 14:59:20 +01:00
|
|
|
|
2019-10-31 12:53:23 +00:00
|
|
|
OBJECTS=AtomBusMon.o status.o $(CPU_OBJECTS)
|
2017-07-26 14:59:20 +01:00
|
|
|
|
|
|
|
build: $(TARGET).mcs
|
|
|
|
|
|
|
|
$(TARGET).mcs: $(TARGET).bit
|
|
|
|
promgen -u 0 $(TARGET).bit -o $(TARGET).mcs -p mcs -w -spi -s 8192
|
|
|
|
rm -f $(TARGET).cfi $(TARGET).prm
|
|
|
|
|
|
|
|
working/$(PROJECT).bit:
|
|
|
|
# create a working directory if necessary
|
|
|
|
mkdir -p working
|
|
|
|
# use the xilinx tools to synthesise the project and generate a bitstream file
|
|
|
|
xtclsh $(COMMON)/ise_build.tcl $(TARGET).xise
|
|
|
|
|
|
|
|
$(TARGET).bit: $(PROG).mem working/$(PROJECT).bit
|
|
|
|
data2mem -bm $(BMM_FILE) -bd $(PROG).mem -bt working/$(PROJECT).bit -o b $(TARGET).bit
|
|
|
|
|
2019-10-31 12:53:23 +00:00
|
|
|
$(PROG).mem: $(PROG).bin
|
|
|
|
od -An -tx1 -w16 -v <$(PROG).bin >$(PROG).mem
|
2017-07-26 14:59:20 +01:00
|
|
|
|
2019-10-31 12:53:23 +00:00
|
|
|
$(PROG).bin : $(PROG).out
|
|
|
|
$(OBJCOPY) -R .comment --reverse-bytes=2 -O binary $(PROG).out $(PROG).bin
|
2017-07-26 14:59:20 +01:00
|
|
|
|
|
|
|
$(PROG).out : $(OBJECTS)
|
|
|
|
$(CC) $(CFLAGS) -o $(PROG).out -Wl,-Map,$(PROG).map $^
|
|
|
|
|
2019-10-31 12:53:23 +00:00
|
|
|
%.o : %.c
|
2017-07-26 14:59:20 +01:00
|
|
|
$(CC) $(CFLAGS) -Os -c $<
|
|
|
|
|
|
|
|
%.o : %.S
|
|
|
|
$(CC) $(CFLAGS) -Os -c $<
|
|
|
|
|
|
|
|
clean:
|
2019-10-31 12:53:23 +00:00
|
|
|
rm -f $(TARGET).bit $(TARGET).mcs $(PROG).mem $(PROG).bin $(PROG).out $(PROG).map *.o
|
2017-07-26 14:59:20 +01:00
|
|
|
|
|
|
|
clobber: clean
|
2019-11-02 15:18:33 +00:00
|
|
|
rm -rf $(BMM_FILE) working/ iseconfig/
|