问题描述
我正在尝试在不同时钟域的2个模块之间同步信号束。我可以通过手动实例化它们之间的AsyncQueue来做到这一点,并且还要注意为每一侧挂钟和重置时钟。似乎有一种似乎不太可行的方法来使用AsyncBundle
,并且我需要一些有关如何操作的指南。
在源代码方面(在clkA处),我有:
val ioA = IO(Decoupled(UInt(32.W))
在水槽一侧(位于clkB),我有:
val ioB = IO(Decoupled(UInt(32.W).flip)
做这样的事情很有意义(我不确定下面的代码是否正确):
// in module A
val ioA = IO(new AsyncBundle(Decoupled(UInt(32.W))))
// in module B
val ioB = IO (new AsyncBundle(Decoupled(UInt(32.W)).flip)
// and somewhere in a module that contains both modules
b.io <> FromAsyncBundle(a.io)
以上是否有意义?我还注意到FromAsyncBundle
创建了一个Decoupledio
,它取代了我在捆绑包中定义的那个,还是只是为了交叉?
如果确实替换了我如何驱动它,例如从某些逻辑推入数据和有效。
那过境的哪一侧的时钟呢?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)