【发布时间】:2021-05-22 14:21:00
【问题描述】:
我正在为我被告知的一种漏斗移位器编写 Chisel 代码。 基本上,它获取大小为 m 位的输入并发送大小为 n 位的输出,其中 m 和 n 可以有任何关系。
我将 m 位字保存在缓冲区中,然后需要动态索引到缓冲区中以获取 n 位。同样,对于写作,我必须在 n 而不是 m 的边界处写作,以免产生碎片。为此,我使用 read_pointer 和 write_pointer 寄存器。需要使用指针作为索引从缓冲区中选择位。
但是 Chisel 不允许我将一个寄存器用作另一个寄存器的索引值。我怎样才能做到这一点 ?代码为 -
when (io.pull && !(io.empty))
{
when ((buffer_rp +& out_word_size.U) <= (buffer_size-1).U ) // No wraparound
{
io.data_out := buffer (buffer_rp + (out_word_size - 1).U, buffer_rp)
}
.otherwise // Wraparound
{
}
}
我得到的错误信息是 -
cmd24.sc:87:重载方法值适用于替代方案: (x: BigInt,y: BigInt)chisel3.UInt (x: Int,y: Int)chisel3.UInt 不能应用于 (chisel3.UInt, chisel3.UInt) io.data_out := 缓冲区 (buffer_rp + (out_word_size - 1).U, buffer_rp) ^编译失败
谢谢
【问题讨论】: