aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWade Fife <wade.fife@ettus.com>2020-05-15 14:04:38 -0500
committerWade Fife <wade.fife@ettus.com>2020-05-26 13:36:55 -0500
commit90933d9b2faf392fd26f3f7ca32f73719614a40a (patch)
tree18d861b4b7a83054c7b9bc5c6e937bac73fe3458
parenta24cfbac866ba713714dcddb753d4ad808d200c6 (diff)
downloaduhd-90933d9b2faf392fd26f3f7ca32f73719614a40a.tar.gz
uhd-90933d9b2faf392fd26f3f7ca32f73719614a40a.tar.bz2
uhd-90933d9b2faf392fd26f3f7ca32f73719614a40a.zip
fpga: tools: Add contents of directories for HDL source
For HLS builds, the output file names aren't known in advance. This makes it difficult to write the Makefile to pull in the files and pass them to the build tools. This change allows you to add a directory as your HDL source so that all files in the directory will be pulled in by the build process.
-rw-r--r--fpga/usrp3/tools/make/viv_hls_ip_builder.mak2
-rw-r--r--fpga/usrp3/tools/scripts/viv_sim_project.tcl20
-rw-r--r--fpga/usrp3/tools/scripts/viv_utils.tcl9
3 files changed, 26 insertions, 5 deletions
diff --git a/fpga/usrp3/tools/make/viv_hls_ip_builder.mak b/fpga/usrp3/tools/make/viv_hls_ip_builder.mak
index 77f09157f..10c5a8330 100644
--- a/fpga/usrp3/tools/make/viv_hls_ip_builder.mak
+++ b/fpga/usrp3/tools/make/viv_hls_ip_builder.mak
@@ -4,7 +4,7 @@
# -------------------------------------------------------------------
# Usage: BUILD_VIVADO_HLS_IP
-# Args: $1 = HLS_IP_NAME (High level synthsis IP name)
+# Args: $1 = HLS_IP_NAME (High level synthesis IP name)
# $2 = PART_ID (<device>/<package>/<speedgrade>)
# $3 = HLS_IP_SRCS (Absolute paths to the HLS IP source files)
# $4 = HLS_IP_SRC_DIR (Absolute path to the top level HLS IP src dir)
diff --git a/fpga/usrp3/tools/scripts/viv_sim_project.tcl b/fpga/usrp3/tools/scripts/viv_sim_project.tcl
index b524e332c..922c1edcc 100644
--- a/fpga/usrp3/tools/scripts/viv_sim_project.tcl
+++ b/fpga/usrp3/tools/scripts/viv_sim_project.tcl
@@ -40,6 +40,15 @@ if [expr ([string equal $simulator "XSim"] == 0) && ([string length $sim_complib
puts "BUILDER: Creating Vivado simulation project part $part_name"
create_project -part $part_name -force $project_name/$project_name
+# Expand directories to include their contents (needed for HLS outputs)
+foreach src_file $design_srcs {
+ if [expr [file isdirectory $src_file] == 1] {
+ puts "BUILDER: Expanding Directory : $src_file"
+ set dir_contents [glob $src_file/*.*]
+ append design_srcs " " $dir_contents
+ }
+}
+
foreach src_file $design_srcs {
set src_ext [file extension $src_file ]
if [expr [lsearch {.vhd .vhdl} $src_ext] >= 0] {
@@ -60,12 +69,15 @@ foreach src_file $design_srcs {
} elseif [expr [lsearch {.ngc .edif} $src_ext] >= 0] {
puts "BUILDER: Adding Netlist : $src_file"
read_edif $src_file
+ } elseif [expr [lsearch {.dat} $src_ext] >= 0] {
+ puts "BUILDER: Adding Data File : $src_file"
+ add_files -fileset $sim_fileset -norecurse $src_file
} elseif [expr [lsearch {.bd} $src_ext] >= 0] {
- puts "BUILDER: Adding Block Diagram: $src_file"
- add_files -norecurse $src_file
+ puts "BUILDER: Adding Block Diagram: $src_file"
+ add_files -norecurse $src_file
} elseif [expr [lsearch {.bxml} $src_ext] >= 0] {
- puts "BUILDER: Adding Block Diagram XML: $src_file"
- add_files -norecurse $src_file
+ puts "BUILDER: Adding Block Diagram XML: $src_file"
+ add_files -norecurse $src_file
} else {
puts "BUILDER: \[WARNING\] File ignored!!!: $src_file"
}
diff --git a/fpga/usrp3/tools/scripts/viv_utils.tcl b/fpga/usrp3/tools/scripts/viv_utils.tcl
index 8f34df6f5..9ced39edf 100644
--- a/fpga/usrp3/tools/scripts/viv_utils.tcl
+++ b/fpga/usrp3/tools/scripts/viv_utils.tcl
@@ -59,6 +59,15 @@ proc ::vivado_utils::initialize_project { {save_to_disk 0} } {
create_project -in_memory -part $g_part_name
}
+ # Expand directories to include their contents (needed for HLS outputs)
+ foreach src_file $g_source_files {
+ if [expr [file isdirectory $src_file] == 1] {
+ puts "BUILDER: Expanding Directory : $src_file"
+ set dir_contents [glob $src_file/*.*]
+ append design_srcs " " $dir_contents
+ }
+ }
+
foreach src_file $g_source_files {
set src_ext [file extension $src_file ]
if [expr [lsearch {.vhd .vhdl} $src_ext] >= 0] {