TCL如何抓有多个fanin的cdc path?

这篇文章描述了一个名为procproc_check_cdc_multi_driven的脚本,用于检查异步信号列表中是否存在由多个驱动引起的驱动冲突。它遍历文件,分析时钟关系以确定是否存在问题,并在发现问题时生成报告。
摘要由CSDN通过智能技术生成
proc proc_check_cdc_multi_driven {async_file_list} {
	set file1 [open "$async_file_list" r]
	while {[gets $file1 line] != -1 } {
	    set ep_clk [get_attribute [get_pins -hierarchical -filter "full_name =~ $line/CP"] clocks]
	    set all_fanin_cell [all_fanin -flat -to [get_pins -hierarchical -filter "full_name =~ $line/D*"] -startpoints_only]]
	    set all_fanin_cell_num [sizeof_collection $all_fanin_cell]
	    if {$all_fanin_cell_num > 1} {
		set num 0
		foreach_in_collection stp_clks $all_fanin_cell {
		    set stp_clk [get_attribute $stp_clks clocks]
		    set clk_relation [get_clock_relationship "$stp_clk $ep_clk" -type asynchronous]
		    if {$clk_relation == "true"} {
			incr num
		    }
		}
		if {num > 1} {
			echo "Error:$line is driven by multiple drive" >> ./cdc_issue.rpt
		}
	    }	    
	}     
    close file1
}

其中输入为: async cell 的list,具体情况根据async cell list来决定是否微调脚本,

灵活运用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值