开始尝试FPGA学习了,学了一个多月吧,还在基于Verilog 进行编译,针对最近遇见的一个头疼的error 10200 发表一下自己的看法:
首先上报错信息:
Error (10200): cannot match operand(s) in the condition to the corresponding edges in the enclosing event control of the always construct
报错代码:
if( sys_hour == 6'b11_1100)
sys_hour 是我定义的 6位寄存器
网上找到的针对10200报错的原因,大哥们基本说的都是针对下降沿信号也就是negedge 信号的处理,当时我就纳闷了,我这设定的是数据判断呀!
后来在尝试下,针对reg类型的信号判断,也要进行取反对比
if( !sys_hour == 6'b00_0011)
这个样子就OK啦
在学习FPGA的Verilog编程中,作者分享了遇到的Error 10200问题,该错误源于不理解如何正确处理非边缘触发的条件。通过实例说明,发现对于reg类型的信号,判断时需要考虑取反操作,修正后的代码解决了问题。
:关于Quartus II Verilog错误代码10200&spm=1001.2101.3001.5002&articleId=120524386&d=1&t=3&u=b2ca6e56c739450c9bf9c09f36ffc7db)
5310

被折叠的 条评论
为什么被折叠?



