File: build_e320.tcl

package info (click to toggle)
uhd 4.8.0.0%2Bds1-2
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 183,172 kB
  • sloc: cpp: 279,415; python: 109,850; ansic: 103,348; vhdl: 57,230; tcl: 20,007; xml: 8,581; makefile: 2,863; sh: 2,797; pascal: 230; javascript: 120; csh: 94; asm: 20; perl: 11
file content (42 lines) | stat: -rw-r--r-- 1,701 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#
# Copyright 2024 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 e3xx_strategy [dict create]
dict set e3xx_strategy "implementation.incremental"              0
dict set e3xx_strategy "opt_design.is_enabled"                   1
dict set e3xx_strategy "opt_design.directive"                    "Default"
dict set e3xx_strategy "post_opt_power_opt_design.is_enabled"    0
dict set e3xx_strategy "place_design.directive"                  "Default"
dict set e3xx_strategy "post_place_power_opt_design.is_enabled"  0
dict set e3xx_strategy "post_place_phys_opt_design.is_enabled"   1
dict set e3xx_strategy "post_place_phys_opt_design.directive"    "Default"
dict set e3xx_strategy "route_design.directive"                  "Default"
dict set e3xx_strategy "route_design.more_options"               "-tns_cleanup"
dict set e3xx_strategy "post_route_phys_opt_design.is_enabled"   1
dict set e3xx_strategy "post_route_phys_opt_design.directive"    "Default"
vivado_strategies::implement_design $e3xx_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