首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用UInt的log2Ceil

使用UInt的log2Ceil
EN

Stack Overflow用户
提问于 2020-02-25 20:38:17
回答 1查看 324关注 0票数 4

我采用了以下计算的log2:

代码语言:javascript
复制
tl_out.a.bits.size := log2Ceil(s1_row * s2_column * 4.U)

其中,s1_row和s2_column是UInt。我收到以下错误:

代码语言:javascript
复制
[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 failed

log2Ceil似乎不能在UInt/SInt上执行。有没有办法将UInt /UInt类型转换成可以通过UInt执行的log2Ceil的替代方法?请协助...

感谢和问候,

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 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()反转信号中的位顺序。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60394862

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档