微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决如何在凿子中的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.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?