aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/top/x400/build_x4xx.tcl
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/build_x4xx.tcl
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/build_x4xx.tcl')
-rw-r--r--fpga/usrp3/top/x400/build_x4xx.tcl38
1 files changed, 38 insertions, 0 deletions
diff --git a/fpga/usrp3/top/x400/build_x4xx.tcl b/fpga/usrp3/top/x400/build_x4xx.tcl
new file mode 100644
index 000000000..0e8b38462
--- /dev/null
+++ b/fpga/usrp3/top/x400/build_x4xx.tcl
@@ -0,0 +1,38 @@
+#
+# Copyright 2021 Ettus Research, a National Instruments Brand
+#
+# SPDX-License-Identifier: LGPL-3.0-or-later
+#
+
+source $::env(VIV_TOOLS_DIR)/scripts/viv_utils.tcl
+source $::env(VIV_TOOLS_DIR)/scripts/viv_strategies.tcl
+
+# STEP#1: Create project, add sources, refresh IP
+vivado_utils::initialize_project
+
+# STEP#2: Run synthesis
+
+
+vivado_utils::synthesize_design
+vivado_utils::generate_post_synth_reports
+
+# STEP#3: Run implementation strategy
+set strategy [vivado_strategies::get_impl_preset "Performance_ExplorePostRoutePhysOpt"]
+# Turn up uncertainty on 100Gb clocks(-quiet so if it fails because the clocks don't exist, it won't error)
+set_clock_uncertainty 0.5 -quiet -setup [get_clocks txoutclk_out*]
+# Vivado has been underestimating routing delays.
+dict set strategy "place_design.directive" "ExtraNetDelay_high"
+# Turn down uncertainty on 100Gb clocks
+dict set strategy "route_design.pre_hook" {set_clock_uncertainty 0.0 -quiet -setup [get_clocks txoutclk_out*]}
+vivado_strategies::implement_design $strategy
+
+# STEP#4: Generate reports
+vivado_utils::generate_post_route_reports
+
+# STEP#5: Generate a bitstream, netlist and debug probes
+set_property BITSTREAM.CONFIG.USR_ACCESS TIMESTAMP [get_designs *]
+set byte_swap_bin 1
+vivado_utils::write_implementation_outputs $byte_swap_bin
+
+# Cleanup
+vivado_utils::close_batch_project