如何在凿子中的2个时钟域之间同步捆绑

问题描述

我正在尝试在不同时钟域的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 (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...