为什么?谁能回答“为什么”?好吧,也许 Mentor 的产品工程师或开发人员推动了这种行为的产生,可以回答这个问题。但缺乏这一点,我们只能猜测。这就是我在这里所做的。
我可以想到一些可能的用例,但它们并不是不能以其他方式完成的。例如,可以有一个通用的“测试台控制器”,它依赖于泛型/参数可以调用某些模拟器行为。(编辑:重新阅读您的链接之一后,我发现这是确切的用例。)
例如,假设我有这个“通用”测试台代码:
module testbench;
parameter LOG_SIGNALS = 1'b0;
initial
begin
if LOG_SIGNALS
begin
// Log all signals in the design
mti_fli::mti_Cmd("add wave -r /*")
end
endmodule
然后,可以将其调用为:
vsim -c -gLOG_SIGNALS=1 work.testbench
最大的用例可能vsim
是从某个环境调用。如果要创建do
文件,我不确定是否可以将参数传递给脚本。说一个有以下do
文件:
if {$log_signals} {
add wave -r /*
}
如何$log_signals
从命令行设置?我想可以通过环境变量来做到这一点,例如:
if { [info exists ::env(LOG_SIGNALS)] } {
add wave -r /*
}
其他用例可能是打开/关闭覆盖数据的捕获、列表文件,甚至可能是结束模拟的古怪案例。
但当然,所有这些都可以通过其他方式来处理。我认为在方式上更清晰,更容易维护。
至于 VerTCL,我觉得很吸引人。但不完整。或者至少是准系统。我发现脚本化的 testenches 非常有用(我们在我工作的地方使用它们)。而 VerTCL 是一个很好的方法(如果你喜欢 TCL)。但它确实需要一些围绕它的框架来读取信号、驱动信号以及以其他方式管理模拟。