2020-04-22 06:58:52 -04:00
|
|
|
mkfile_path := $(abspath $(lastword $(MAKEFILE_LIST)))
|
|
|
|
current_dir := $(patsubst %/,%,$(dir $(mkfile_path)))
|
|
|
|
TOP := top
|
|
|
|
VERILOG := ${current_dir}/baselitex_arty.v \
|
|
|
|
${current_dir}/VexRiscv_Linux.v
|
|
|
|
MEM_INIT := ${current_dir}/mem.init \
|
|
|
|
${current_dir}/mem_1.init \
|
|
|
|
${current_dir}/mem_2.init
|
|
|
|
PARTNAME := xc7a35tcsg324-1
|
|
|
|
DEVICE := xc7a50t_test
|
|
|
|
BITSTREAM_DEVICE := artix7
|
|
|
|
PCF := ${current_dir}/arty.pcf
|
2020-04-23 06:59:27 -04:00
|
|
|
SDC := ${current_dir}/arty.sdc
|
2020-04-22 06:58:52 -04:00
|
|
|
BUILDDIR := build
|
|
|
|
|
|
|
|
all: ${BUILDDIR}/${TOP}.bit
|
|
|
|
|
|
|
|
${BUILDDIR}:
|
|
|
|
mkdir ${BUILDDIR}
|
|
|
|
ln -s ${MEM_INIT} ${BUILDDIR}
|
|
|
|
|
|
|
|
${BUILDDIR}/${TOP}.eblif: | ${BUILDDIR}
|
|
|
|
cd ${BUILDDIR} && synth -t ${TOP} -v ${VERILOG} -d ${BITSTREAM_DEVICE} -p ${PARTNAME} 2>&1 > /dev/null
|
|
|
|
|
|
|
|
${BUILDDIR}/${TOP}.net: ${BUILDDIR}/${TOP}.eblif
|
2020-04-23 06:59:27 -04:00
|
|
|
cd ${BUILDDIR} && pack -e ${TOP}.eblif -d ${DEVICE} -s ${SDC} 2>&1 > /dev/null
|
2020-04-22 06:58:52 -04:00
|
|
|
|
|
|
|
${BUILDDIR}/${TOP}.place: ${BUILDDIR}/${TOP}.net
|
2020-04-23 06:59:27 -04:00
|
|
|
cd ${BUILDDIR} && place -e ${TOP}.eblif -d ${DEVICE} -p ${PCF} -n ${TOP}.net -P ${PARTNAME} -s ${SDC} 2>&1 > /dev/null
|
2020-04-22 06:58:52 -04:00
|
|
|
|
|
|
|
${BUILDDIR}/${TOP}.route: ${BUILDDIR}/${TOP}.place
|
2020-04-23 06:59:27 -04:00
|
|
|
cd ${BUILDDIR} && route -e ${TOP}.eblif -d ${DEVICE} -s ${SDC} 2>&1 > /dev/null
|
2020-04-22 06:58:52 -04:00
|
|
|
|
|
|
|
${BUILDDIR}/${TOP}.fasm: ${BUILDDIR}/${TOP}.route
|
|
|
|
cd ${BUILDDIR} && write_fasm -e ${TOP}.eblif -d ${DEVICE}
|
|
|
|
|
|
|
|
${BUILDDIR}/${TOP}.bit: ${BUILDDIR}/${TOP}.fasm
|
|
|
|
cd ${BUILDDIR} && write_bitstream -d ${BITSTREAM_DEVICE} -f ${TOP}.fasm -p ${PARTNAME} -b ${TOP}.bit
|
|
|
|
|
|
|
|
clean:
|
|
|
|
rm -rf ${BUILDDIR}
|
|
|
|
|