如何解决如何在凿子中的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 举报,一经查实,本站将立刻删除。