add TE0713+UMFT601X-B FT601 integration dev bitstream (timing clean)
FMC LPC dev build for TE0713/TE0701 + UMFT601X-B stack. Fixed timing closure: replaced set_output_delay with set_max_delay -datapath_only to eliminate false IBUF+BUFG clock skew penalty on source-synchronous outputs. Removed erroneous set_input_delay on output-only ft601_be[*]. Added IOB packing for siwu_n, false paths for async GPIO/reset/wakeup. Strategy: Performance_ExplorePostRoutePhysOpt. Results: WNS +0.059 ns, WHS +0.121 ns, DRC 0 errors, 0 failing endpoints. Bitstream: docs/artifacts/te0713-te0701-umft601x-dev-2026-03-21.bit
This commit is contained in:
@@ -0,0 +1,57 @@
|
||||
# build_te0713_umft601x_dev.tcl
|
||||
#
|
||||
# Vivado batch build for Trenz TE0713/TE0701 with UMFT601X-B over FMC LPC.
|
||||
|
||||
set script_dir [file dirname [file normalize [info script]]]
|
||||
set project_root [file normalize [file join $script_dir ".."]]
|
||||
|
||||
set project_name "aeris10_te0713_umft601x_dev"
|
||||
set build_dir [file join $project_root "vivado_te0713_umft601x_dev"]
|
||||
set reports_dir [file join $build_dir "reports"]
|
||||
|
||||
set top_file [file join $project_root "radar_system_top_te0713_umft601x_dev.v"]
|
||||
set usb_file [file join $project_root "usb_data_interface.v"]
|
||||
set xdc_file [file join $project_root "constraints" "te0713_te0701_umft601x.xdc"]
|
||||
|
||||
file mkdir $build_dir
|
||||
file mkdir $reports_dir
|
||||
|
||||
create_project -force $project_name $build_dir -part xc7a200tfbg484-2
|
||||
set_property target_language Verilog [current_project]
|
||||
|
||||
add_files -norecurse $top_file
|
||||
add_files -norecurse $usb_file
|
||||
add_files -fileset constrs_1 -norecurse $xdc_file
|
||||
|
||||
set_property top radar_system_top_te0713_umft601x_dev [current_fileset]
|
||||
update_compile_order -fileset sources_1
|
||||
|
||||
# Use Performance_ExplorePostRoutePhysOpt strategy for timing closure
|
||||
set_property strategy Performance_ExplorePostRoutePhysOpt [get_runs impl_1]
|
||||
|
||||
puts "INFO: Launching implementation to bitstream (Performance_ExplorePostRoutePhysOpt)..."
|
||||
launch_runs impl_1 -to_step write_bitstream -jobs 8
|
||||
wait_on_run impl_1
|
||||
|
||||
set impl_status [get_property STATUS [get_runs impl_1]]
|
||||
puts "INFO: impl_1 status: $impl_status"
|
||||
|
||||
if {![string match "*Complete*" $impl_status]} {
|
||||
error "Implementation did not complete successfully. Status: $impl_status"
|
||||
}
|
||||
|
||||
open_run impl_1
|
||||
|
||||
report_clocks -file [file join $reports_dir "clocks.rpt"]
|
||||
report_clock_interaction -file [file join $reports_dir "clock_interaction.rpt"]
|
||||
report_timing_summary -report_unconstrained -max_paths 100 -file [file join $reports_dir "timing_summary.rpt"]
|
||||
report_cdc -details -file [file join $reports_dir "cdc.rpt"]
|
||||
report_exceptions -file [file join $reports_dir "exceptions.rpt"]
|
||||
report_drc -file [file join $reports_dir "drc.rpt"]
|
||||
report_utilization -file [file join $reports_dir "utilization.rpt"]
|
||||
|
||||
set bit_file [get_property BITSTREAM.FILE [current_design]]
|
||||
|
||||
puts "INFO: Build complete."
|
||||
puts "INFO: Bitstream: $bit_file"
|
||||
puts "INFO: Reports: $reports_dir"
|
||||
Reference in New Issue
Block a user