mirror of
https://github.com/corundum/corundum.git
synced 2025-01-16 08:12:53 +08:00
86 lines
3.9 KiB
Makefile
86 lines
3.9 KiB
Makefile
|
|
# FPGA settings
|
|
FPGA_PART = xcvu9p-flga2104-2L-e
|
|
FPGA_TOP = fpga
|
|
FPGA_ARCH = virtexuplus
|
|
|
|
# Files for synthesis
|
|
SYN_FILES = rtl/fpga.v
|
|
SYN_FILES += rtl/fpga_core.v
|
|
SYN_FILES += rtl/debounce_switch.v
|
|
SYN_FILES += rtl/sync_reset.v
|
|
SYN_FILES += rtl/sync_signal.v
|
|
SYN_FILES += rtl/axi_ram.v
|
|
SYN_FILES += rtl/axis_register.v
|
|
SYN_FILES += lib/pcie/rtl/axis_arb_mux.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_axil_master.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_axi_dma.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_axi_dma_rd.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_axi_dma_wr.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_axi_master.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_axi_master_rd.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_axi_master_wr.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_axis_cq_demux.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_cfg.v
|
|
SYN_FILES += lib/pcie/rtl/pcie_us_msi.v
|
|
SYN_FILES += lib/pcie/rtl/arbiter.v
|
|
SYN_FILES += lib/pcie/rtl/priority_encoder.v
|
|
SYN_FILES += lib/pcie/rtl/pulse_merge.v
|
|
|
|
# XDC files
|
|
XDC_FILES = fpga.xdc
|
|
|
|
# IP
|
|
IP_TCL_FILES = ip/pcie4_uscale_plus_0.tcl
|
|
|
|
include ../common/vivado.mk
|
|
|
|
program: $(FPGA_TOP).bit
|
|
echo "open_hw" > program.tcl
|
|
echo "connect_hw_server" >> program.tcl
|
|
echo "open_hw_target" >> program.tcl
|
|
echo "current_hw_device [lindex [get_hw_devices] 0]" >> program.tcl
|
|
echo "refresh_hw_device -update_hw_probes false [current_hw_device]" >> program.tcl
|
|
echo "set_property PROGRAM.FILE {$(FPGA_TOP).bit} [current_hw_device]" >> program.tcl
|
|
echo "program_hw_devices [current_hw_device]" >> program.tcl
|
|
echo "exit" >> program.tcl
|
|
vivado -nojournal -nolog -mode batch -source program.tcl
|
|
|
|
%_primary.mcs %_secondary.mcs %_primary.prm %_secondary.prm: %.bit
|
|
echo "write_cfgmem -force -format mcs -size 256 -interface SPIx8 -loadbit {up 0x0000000 $*.bit} -checksum -file $*.mcs" > generate_mcs.tcl
|
|
echo "exit" >> generate_mcs.tcl
|
|
vivado -nojournal -nolog -mode batch -source generate_mcs.tcl
|
|
mkdir -p rev
|
|
COUNT=100; \
|
|
while [ -e rev/$*_rev$$COUNT.bit ]; \
|
|
do COUNT=$$((COUNT+1)); done; \
|
|
COUNT=$$((COUNT-1)); \
|
|
for x in _primary.mcs _secondary.mcs _primary.prm _secondary.prm; \
|
|
do cp $*$$x rev/$*_rev$$COUNT$$x; \
|
|
echo "Output: rev/$*_rev$$COUNT$$x"; done;
|
|
|
|
flash: $(FPGA_TOP)_primary.mcs $(FPGA_TOP)_secondary.mcs $(FPGA_TOP)_primary.prm $(FPGA_TOP)_secondary.prm
|
|
echo "open_hw" > flash.tcl
|
|
echo "connect_hw_server" >> flash.tcl
|
|
echo "open_hw_target" >> flash.tcl
|
|
echo "current_hw_device [lindex [get_hw_devices] 0]" >> flash.tcl
|
|
echo "refresh_hw_device -update_hw_probes false [current_hw_device]" >> flash.tcl
|
|
echo "create_hw_cfgmem -hw_device [current_hw_device] [lindex [get_cfgmem_parts {mt25qu01g-spi-x1_x2_x4_x8}] 0]" >> flash.tcl
|
|
echo "current_hw_cfgmem -hw_device [current_hw_device] [get_property PROGRAM.HW_CFGMEM [current_hw_device]]" >> flash.tcl
|
|
echo "set_property PROGRAM.FILES [list \"$(FPGA_TOP)_primary.mcs\" \"$(FPGA_TOP)_secondary.mcs\"] [current_hw_cfgmem]" >> flash.tcl
|
|
echo "set_property PROGRAM.PRM_FILES [list \"$(FPGA_TOP)_primary.prm\" \"$(FPGA_TOP)_secondary.prm\"] [current_hw_cfgmem]" >> flash.tcl
|
|
echo "set_property PROGRAM.ERASE 1 [current_hw_cfgmem]" >> flash.tcl
|
|
echo "set_property PROGRAM.CFG_PROGRAM 1 [current_hw_cfgmem]" >> flash.tcl
|
|
echo "set_property PROGRAM.VERIFY 1 [current_hw_cfgmem]" >> flash.tcl
|
|
echo "set_property PROGRAM.CHECKSUM 0 [current_hw_cfgmem]" >> flash.tcl
|
|
echo "set_property PROGRAM.ADDRESS_RANGE {use_file} [current_hw_cfgmem]" >> flash.tcl
|
|
echo "set_property PROGRAM.UNUSED_PIN_TERMINATION {pull-none} [current_hw_cfgmem]" >> flash.tcl
|
|
echo "create_hw_bitstream -hw_device [current_hw_device] [get_property PROGRAM.HW_CFGMEM_BITFILE [current_hw_device]]" >> flash.tcl
|
|
echo "program_hw_devices [current_hw_device]" >> flash.tcl
|
|
echo "refresh_hw_device [current_hw_device]" >> flash.tcl
|
|
echo "program_hw_cfgmem -hw_cfgmem [current_hw_cfgmem]" >> flash.tcl
|
|
echo "boot_hw_device [current_hw_device]" >> flash.tcl
|
|
echo "exit" >> flash.tcl
|
|
vivado -nojournal -nolog -mode batch -source flash.tcl
|
|
|