aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/top/x400/Makefile.x4xx.inc
diff options
context:
space:
mode:
authorWade Fife <wade.fife@ettus.com>2021-06-08 19:40:46 -0500
committerAaron Rossetto <aaron.rossetto@ni.com>2021-06-10 11:56:58 -0500
commit6d3765605262016a80f71e36357f749ea35cbe5a (patch)
tree7d62d6622befd4132ac1ee085effa1426f7f53e5 /fpga/usrp3/top/x400/Makefile.x4xx.inc
parentf706b89e6974e28ce76aadeeb06169becc86acba (diff)
downloaduhd-6d3765605262016a80f71e36357f749ea35cbe5a.tar.gz
uhd-6d3765605262016a80f71e36357f749ea35cbe5a.tar.bz2
uhd-6d3765605262016a80f71e36357f749ea35cbe5a.zip
fpga: x400: Add support for X410 motherboard FPGA
Co-authored-by: Andrew Moch <Andrew.Moch@ni.com> Co-authored-by: Daniel Jepson <daniel.jepson@ni.com> Co-authored-by: Javier Valenzuela <javier.valenzuela@ni.com> Co-authored-by: Joerg Hofrichter <joerg.hofrichter@ni.com> Co-authored-by: Kumaran Subramoniam <kumaran.subramoniam@ni.com> Co-authored-by: Max Köhler <max.koehler@ni.com> Co-authored-by: Michael Auchter <michael.auchter@ni.com> Co-authored-by: Paul Butler <paul.butler@ni.com> Co-authored-by: Wade Fife <wade.fife@ettus.com> Co-authored-by: Hector Rubio <hrubio@ni.com>
Diffstat (limited to 'fpga/usrp3/top/x400/Makefile.x4xx.inc')
-rw-r--r--fpga/usrp3/top/x400/Makefile.x4xx.inc197
1 files changed, 197 insertions, 0 deletions
diff --git a/fpga/usrp3/top/x400/Makefile.x4xx.inc b/fpga/usrp3/top/x400/Makefile.x4xx.inc
new file mode 100644
index 000000000..3bcbe38cd
--- /dev/null
+++ b/fpga/usrp3/top/x400/Makefile.x4xx.inc
@@ -0,0 +1,197 @@
+#
+# Copyright 2021 Ettus Research, a National Instruments Brand
+#
+# SPDX-License-Identifier: LGPL-3.0-or-later
+#
+
+##################################################
+# Project Setup
+##################################################
+# TOP_MODULE = <Input arg>
+# NAME = <Input arg>
+# PART_ID = <Input arg>
+# ARCH = <Input arg>
+
+##################################################
+# Include other makefiles
+##################################################
+
+BASE_DIR = $(abspath ..)
+IP_DIR = $(abspath ./ip)
+include $(BASE_DIR)/../tools/make/viv_design_builder.mak
+
+# Include IP directory
+include $(IP_DIR)/Makefile.inc
+
+# Include any LIB dependencies
+include coregen_dsp/Makefile.srcs
+include $(LIB_DIR)/control/Makefile.srcs
+include $(LIB_DIR)/fifo/Makefile.srcs
+include $(LIB_DIR)/xge/Makefile.srcs
+include $(LIB_DIR)/xge_interface/Makefile.srcs
+include $(LIB_DIR)/axi/Makefile.srcs
+include $(LIB_DIR)/packet_proc/Makefile.srcs
+include $(LIB_DIR)/dsp/Makefile.srcs
+include $(LIB_DIR)/ip/Makefile.inc
+include $(LIB_DIR)/rfnoc/Makefile.srcs
+include $(LIB_DIR)/wb_spi/Makefile.srcs
+include $(LIB_DIR)/axi4_sv/Makefile.srcs
+include $(LIB_DIR)/axi4s_sv/Makefile.srcs
+include $(LIB_DIR)/axi4lite_sv/Makefile.srcs
+include $(LIB_DIR)/rfnoc/xport_sv/Makefile.srcs
+
+# For sake of convenience, we include the Makefile.srcs for DRAM FIFO, DDC, and
+# DUC, Replay, and of course the radio. Any other block needs to use the
+# RFNOC_OOT_MAKEFILE_SRCS variable (see below).
+include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_null_src_sink/Makefile.srcs
+include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_radio/Makefile.srcs
+include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_ddc/Makefile.srcs
+include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_duc/Makefile.srcs
+
+# If out-of-tree modules want to be compiled into this image, then they need to
+# pass in the RFNOC_OOT_MAKEFILE_SRCS as a list of Makefile.srcs files.
+# Those files need to amend the RFNOC_OOT_SRCS variable with a list of actual
+# source files.
+include $(RFNOC_OOT_MAKEFILE_SRCS)
+
+IMAGE_CORE ?= $(DEFAULT_RFNOC_IMAGE_CORE_FILE)
+EDGE_FILE ?= $(DEFAULT_EDGE_FILE)
+
+##################################################
+# Sources
+##################################################
+TOP_SRCS =
+
+ifdef X410
+TOP_SRCS += \
+x4xx.v \
+x4xx_qsfp_wrapper_temp.sv \
+x4xx_qsfp_wrapper.sv \
+x4xx_mgt_io_core.sv \
+x4xx_core.v \
+x4xx_core_common.v \
+x4xx_global_regs.v \
+x4xx_versioning_regs.v \
+x4xx_dio.v \
+rf/100m/rf_core_100m.v \
+rf/200m/rf_core_200m.v \
+rf/200m/rf_down_4to2.v \
+rf/200m/rf_up_2to4.v \
+rf/400m/rf_core_400m.v \
+rf/common/rf_reset_controller.vhd \
+ctrlport_spi_master.v \
+cpld_interface.v \
+cpld_interface_regs.v \
+qsfp_led_controller.v \
+rfdc_timing_control.v \
+x4xx_pps_sync.v \
+../../lib/timing/pps_generator.v \
+dboards/ctrlport_byte_serializer.v \
+dboards/db_gpio_interface.v \
+dboards/db_gpio_reordering.v \
+ipass_present_controller.v \
+$(IMAGE_CORE)
+endif
+
+MB_XDC = \
+constraints/pins/common.xdc \
+constraints/pins/rfdc_2x2.xdc \
+constraints/timing/shared_constants.sdc \
+constraints/timing/common.xdc
+
+# Definitions
+# MGT Types from x4xx_mgt_type.vh
+MGT_100GbE = 5
+MGT_Aurora = 3
+MGT_10GbE = 2
+MGT_Disabled = 0
+
+# Check if any of the ports are set to 10Gbe
+ifneq (,$(findstring =$(MGT_10GbE),$(EXTRA_DEFS)))
+ MB_XDC += constraints/timing/qsfp_10gbe.xdc
+endif
+
+# Add pin constraints for QSFP pins
+ifneq (,$(findstring QSFP0_0,"$(EXTRA_DEFS)"))
+ MB_XDC += constraints/pins/qsfp0_0.xdc
+endif
+ifneq (,$(findstring QSFP0_1,$(EXTRA_DEFS)))
+ MB_XDC += constraints/pins/qsfp0_1.xdc
+endif
+ifneq (,$(findstring QSFP0_2,$(EXTRA_DEFS)))
+ MB_XDC += constraints/pins/qsfp0_2.xdc
+endif
+ifneq (,$(findstring QSFP0_3,$(EXTRA_DEFS)))
+ MB_XDC += constraints/pins/qsfp0_3.xdc
+endif
+
+ifneq (,$(findstring QSFP1_0,$(EXTRA_DEFS)))
+ MB_XDC += constraints/pins/qsfp1_0.xdc
+endif
+ifneq (,$(findstring QSFP1_1,$(EXTRA_DEFS)))
+ MB_XDC += constraints/pins/qsfp1_1.xdc
+endif
+ifneq (,$(findstring QSFP1_2,$(EXTRA_DEFS)))
+ MB_XDC += constraints/pins/qsfp1_2.xdc
+endif
+ifneq (,$(findstring QSFP1_3,$(EXTRA_DEFS)))
+ MB_XDC += constraints/pins/qsfp1_3.xdc
+endif
+
+ifndef NO_DRAM_FIFOS
+DRAM_SRCS =
+else
+DRAM_SRCS =
+endif
+
+ifdef X410
+DESIGN_SRCS = $(abspath $(MB_XDC))
+endif
+
+# The XDC files must be read in a specific order, motherboard first and then daughterboard.
+# Outside of that, all the other sources can be read in any order desired.
+DESIGN_SRCS += $(abspath \
+$(AXI4_SV_SRCS) $(AXI4S_SV_SRCS) $(AXI4LITE_SV_SRCS) $(TOP_SRCS) \
+$(AXI_SRCS) $(FIFO_SRCS) \
+$(CONTROL_LIB_SRCS) $(SDR_LIB_SRCS) $(SERDES_SRCS) \
+$(SIMPLE_GEMAC_SRCS) $(TIMING_SRCS) $(COREGEN_DSP_SRCS) \
+$(VRT_SRCS) $(UDP_SRCS) $(COREGEN_SRCS) $(EXTRAM_SRCS) $(WISHBONE_SRCS) \
+$(XGE_SRCS) $(XGE_INTERFACE_SRCS) $(AURORA_PHY_SRCS) \
+$(XGE_PCS_PMA_SRCS) \
+$(PACKET_PROC_SRCS) $(VITA_SRCS) $(DSP_SRCS) $(DRAM_SRCS) \
+$(RADIO_SRCS) $(CAP_GEN_GENERIC_SRCS) $(IP_XCI_SRCS) $(BD_SRCS) \
+$(RFNOC_SRCS) $(RFNOC_OOT_SRCS) $(LIB_IP_XCI_SRCS) $(LIB_HLS_IP_SRCS) $(LIBCOREGEN_SRCS) \
+$(RFNOC_BLOCK_DUC_SRCS) $(RFNOC_BLOCK_DDC_SRCS) \
+$(RFNOC_BLOCK_RADIO_SRCS) $(RFNOC_BLOCK_NULL_SRC_SINK_SRCS) \
+$(DB_COMMON_SRCS) $(WHITE_RABBIT_SRCS) $(RFNOC_FRAMEWORK_SRCS) \
+$(WB_SPI_SRCS) $(RFNOC_XPORT_SV_SRCS) \
+)
+
+# Pass the edge table and image core header files required by RFNoC
+# to Vivado as Verilog definitions.
+EDGE_TBL_DEF="RFNOC_EDGE_TBL_FILE=$(call RESOLVE_PATH,$(EDGE_FILE))"
+IMAGE_CORE_DEF="RFNOC_IMAGE_CORE_HDR=$(DEFAULT_RFNOC_IMAGE_CORE_FILE:.v=.vh)"
+
+##################################################
+# Dependency Targets
+##################################################
+.SECONDEXPANSION:
+
+VERILOG_DEFS=$(EXTRA_DEFS) $(CUSTOM_DEFS) $(GIT_HASH_VERILOG_DEF) $(EDGE_TBL_DEF) $(IMAGE_CORE_DEF)
+
+# DESIGN_SRCS and VERILOG_DEFS must be defined
+bin: .prereqs $$(DESIGN_SRCS) ip
+ @echo "Printing MB_XDC:: $(MB_XDC)"
+ @echo "Printing EXTRA_DEFS:: $(EXTRA_DEFS)"
+ $(call BUILD_VIVADO_DESIGN,$(abspath ./build_x4xx.tcl),$(TOP_MODULE),$(ARCH),$(PART_ID))
+
+synth: .prereqs $$(DESIGN_SRCS) ip
+ $(call BUILD_VIVADO_DESIGN,$(TOOLS_DIR)/scripts/viv_synth.tcl,$(TOP_MODULE),$(ARCH),$(PART_ID))
+
+rtl: .prereqs $$(DESIGN_SRCS) ip
+ $(call CHECK_VIVADO_DESIGN,$(TOOLS_DIR)/scripts/viv_check_syntax.tcl,$(TOP_MODULE),$(ARCH),$(PART_ID))
+
+viv_ip: .prereqs $$(DESIGN_SRCS) ip
+ @echo "IP Build DONE ..."
+
+.PHONY: bin