上期内容:嵌套的for循环,到底对哪个执行pipeline更好
看一个典型的例子,如下图所示。变量x被赋值为10,变量a被赋值为字符x。之后,给变量b赋值$a。最终变量b的值将会是x,而不是10。
为什么b的值是$x,而不是10呢?这是因为Tcl的变量置换遵循如下两条规则:
规则1:Tcl在解析一条命令时,只从左向右解析一次,进行一轮置换,每一个字符只会被扫描一次。
规则2:每一个字符只会发生一层置换,而不会对置换后的结果再进行一次扫描置换。
根据上述规则,Tcl从左向右对命令“set b
a时,执行变量置换,得到
那么如果期望$$a发生二次置换该如何操作呢?
方法1:采用[set var]的方式,如下图所示。代码第6行中括号中的set命令只跟随一个参数var,var发生变量置换,故set var等效于set a,而set a将返回变量a的值。本质上,var是[set var]的缩写版本。通过代码第10行和第12行可以看出,set后面如果只有一个参数,而这个参数又是一个已经定义的变量名,那么该命令就直接返回该变量的变量值,与
方法2:采用命令subst实现此目的,如下图所示。
HLS Math Library:csim ?C/RTL co-sim(2)
HLS Math Library:csim ?C/RTL co-sim(1)
如何降低OSERDES/CLK和CLKDIV的Clock Skew
文 | Lauren 图 | Lauren
Copyright @ Lauren的FPGA
转载事宜请私信 | 获得授权后方可转载