forked from aws/aws-fpga
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapply_debug_constraints.tcl
executable file
·78 lines (74 loc) · 2.91 KB
/
apply_debug_constraints.tcl
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# Amazon FPGA Hardware Development Kit
#
# Copyright 2016 Amazon.com, Inc. or its affiliates. All Rights Reserved.
#
# Licensed under the Amazon Software License (the "License"). You may not use
# this file except in compliance with the License. A copy of the License is
# located at
#
# http://aws.amazon.com/asl/
#
# or in the "license" file accompanying this file. This file is distributed on
# an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, express or
# implied. See the License for the specific language governing permissions and
# limitations under the License.
#checking if HDK_SHELL_DIR env variable exists
if { [info exists ::env(HDK_SHELL_DIR)] } {
set HDK_SHELL_DIR $::env(HDK_SHELL_DIR)
puts "Using Shell directory $HDK_SHELL_DIR";
} else {
puts "Error: HDK_SHELL_DIR environment variable not defined ! ";
puts "Run the hdk_setup.sh script from the root directory of aws-fpga";
exit 2
}
#checking if CL_DIR env variable exists
if { [info exists ::env(CL_DIR)] } {
set CL_DIR $::env(CL_DIR)
puts "Using CL directory $CL_DIR";
} else {
puts "Error: CL_DIR environment variable not defined ! ";
puts "Run the hdk_setup.sh script from the root directory of aws-fpga";
exit 2
}
set dbg_bridge [get_debug_cores -filter {NAME=~WRAPPER_INST/CL/*CL_DEBUG_BRIDGE*}]
if {[llength $dbg_bridge]} {
puts "AWS FPGA: Found debug_bridge instance $dbg_bridge in CL. Processing debug constraints"
if {[llength [get_cells -quiet $dbg_bridge/inst/BSCANID.u_xsdbm_id/CORE_XSDB.UUT_MASTER/U_ICON_INTERFACE/U_CMD6_RD/U_RD_FIFO/SUBCORE_FIFO.xsdbm_v3_0_0_rdfifo_inst]]} {
read_xdc $HDK_SHELL_DIR/build/constraints/cl_debug_bridge.xdc
}
if {[llength [get_cells -quiet $dbg_bridge/inst]]} {
read_xdc -cell $dbg_bridge/inst $HDK_SHELL_DIR/build/constraints/xsdbm_timing_exception.xdc
}
set dbg_cores [get_debug_cores -filter {NAME=~WRAPPER_INST/CL/*}]
if {[llength $dbg_cores] > 1} {
set dbg_hub_cells [list \
*runtest_i_reg \
*tms_i_reg \
]
} else {
set dbg_hub_cells [list \
*runtest_i_reg \
*tms_i_reg \
*update_i_reg \
*shift_i_reg \
*sel_i_reg \
*tdi_i_reg \
*tms_i_reg \
*drck_i_reg \
*reset_i_reg \
*runtest_i_reg \
*capture_i_reg \
*bscanid_en_i_reg \
*bscanid_i_reg[*] \
]
}
foreach cell $dbg_hub_cells {
set dbg_reg [get_cells -quiet -hier -filter NAME=~WRAPPER_INST/CL/*xsdbm*/$cell]
if [llength $dbg_reg] {
foreach reg $dbg_reg {
puts "Setting false path to dbg register $reg"
set_false_path -to [get_pins $reg/D]
}
}
}
}