我采用了以下计算的log2:
tl_out.a.bits.size := log2Ceil(s1_row * s2_column * 4.U)其中,s1_row和s2_column是UInt。我收到以下错误:
[info] Compiling 1 Scala source to ...rocket-chip/target/scala-2.12/classes ...
[error] ...scala:199:25: overloaded method value apply with alternatives:
[error] (in: Int)Int <and>
[error] (in: BigInt)Int
[error] cannot be applied to (chisel3.core.UInt)
[error] tl_out.a.bits.size := log2Ceil(s1_row * s2_column * 4.U)
[error] ^
[error] one error found
[error] (Compile / compileIncremental) Compilation failedlog2Ceil似乎不能在UInt/SInt上执行。有没有办法将UInt /UInt类型转换成可以通过UInt执行的log2Ceil的替代方法?请协助...
感谢和问候,
发布于 2020-02-25 21:52:41
log2Ceil()是一个很好的查找单词大小的函数。但请注意,它不是“可合成”的UInt() Wire或Reg。log2Ceil()计算在合成时执行一次,它不是一个硬件函数。那么你的输出信号tl_out.a.bits.size将是一个常数。
如果要查找最重要的设置位,则应使用名为PriorityEncoder(Reverse(s1_row * s2_column * 4.U))的硬件函数。
PriorityEncoder()返回信号中最不重要的'1‘的位置。并且Reverse()反转信号中的位顺序。
https://stackoverflow.com/questions/60394862
复制相似问题