问题描述
我想知道如何检查 3 位总线的 msb 是否设置为 1,即 1xx。 当我检查 bus==3'b1xx 时似乎什么也没发生。
解决方法
您编写的表达式的结果只能是 (1'b0) 或 (1'bx),对于 if
语句分支,它们都被认为是错误的。
假设您将总线声明为 wire [2:0] bus;
,您可以使用 bus[2] == 1'b1
现在在 SystemVerilog 中,您可以使用 bus ==? 3'b1xx
进行通配符匹配,它将 RHS X 视为无关紧要。 LHS 上的 X 被视为与 ==
相同。