我一直在尝试使用icarus verilog从xilinx提供的unisim librabries编译ICAP_SPARTAN6.v。
我得到下面的编译错误:
/opt/Xilinx/14.3/ISE_DS/ISE/verilog/src/unisims/ICAP_SPARTAN6.v:79: syntax error
/opt/Xilinx/14.3/ISE_DS/ISE/verilog/src/unisims/ICAP_SPARTAN6.v:79: error: invalid module item.相关代码行如下:
tri (weak1, strong0) done_o = p_up;//line 78
tri (pull1, supply0) [15:0] di_t = (icap_idone == 1 && WRITE == 1)? 16'bz : dix; //line 79我还想指出的是,我不是很清楚tri究竟是如何工作的。我假设它类似于一条线,除了有3个状态,但它后面的括号对我来说没有意义,这使得调试变得有点困难:)任何帮助都将不胜感激。-Thanks
发布于 2012-11-09 04:13:25
tri和wire是等效的。
括号中的关键字确定驱动强度,从而允许开关和门级建模。规则有些复杂,但基本上较强的信号可以覆盖较弱的信号,因此在同一信号上驱动pull1和strong0可能会导致0状态,而不是X或Z。
该错误看起来像是iverilog中的bug或缺少的功能。删除向量范围可以成功编译。
https://stackoverflow.com/questions/13285956
复制相似问题