apb/axi异步桥实现

1.基本异步处理电路

1.1电平同步

1.2脉冲同步

现将脉冲变成电平,同步之后再恢复,

1.下面是脉冲展电平的做法

2.下面是电平恢复脉冲

1.3异步fifo

1.4demux同步

DEBUX通过一个同步到目标时钟域的信号作为目标时钟域多比特数据更新的使能信号

2.Qualifier synchronization

其实和demux很相像,先选择一个qualif的singal做同步,同步到ck2之后,用该信号做其他数据的选通信号。

3.apb2apb的异步桥

apb的信号中只有psel和pready会做sync,其他都不直接sync

假设apb2apb的clk_1域为slave 端,需要同步到clk_2域master端

psel_s/penalbe_s/pwrite_s/paddr_s/pwdata_s 需要同步到clk_2

pready_m/prdata_m/pslverr_m需要同步到clk_1

3.1 使用异步fifo的同步形式

这种情况比较简单,但是资源占的较多

3.2Qualifier synchronization 策略(就是打拍的形式)

3.2.1 apb2apb方法二

slave--->master过程如下:

1.将psel_s&(~penable_s)这样一个pulse signal 经过脉冲同步到clk_2,为pulse_d

2.用pulse_d拉高psel_m,用psel_m & penable_m & pready_m 拉低psel_m

3.用pulse_d_ff1拉高penable_m,用psel_m & penable_m & pready_m 拉低penable_m

4.pwrite_m/paddr_m/pwdata_m直接赋值

以上地方直接赋值也可以用psel_m做个mux

assign pwrite_m = psel_m & pwrite_s;

assign paddr_m = psel_m & paddr_s;

assign pwdata_m = psel_m & pwdata_s;

master--->slave过程如下:

1.将psel_m & penable_m & pready_m形成的pulse 信号同步到clk_1做pready_s

2.用psel_m & penable_m & pready_m对prdata_m在clk_2域锁存,锁存的信号直接作为clk_1的prdata_s

3.用psel_m & penable_m & pready_m对pslverr_m在clk_2域锁存,锁存的信号直接作为clk_1的pslverr_s(和prdata_s一样)

其实上面过程是无论那边的clk快,都没有问题。因为正向和反向都是一个dmux结构。

从正向来说 clk_s到clk_m

用psel_s & (~penable_s)做脉冲同步,首先产生电平信号,这个电平信号是从psel_s & (~penable_s)下一拍开始有效的,此时对应的paddr/pwrite/pwdata刚好开始有效,所以是一个完美的demux信号。

从反向clk_m到clk_s

psel_m & penable_m & pready_m的下一拍产生电平信号,同时锁存的prdata/pslverr开始有效,也是一个完美的demux信号

3.2.2 apb2apb方法三

这种情况下 肯定要存在一对信号 从clk_s到clk_m,在从clk_m到clk_s,双向都确认完毕之后在进行下一次传输。思路如下:

在clk_s用psel产生req_s,同步到clk_m, 为req_s2m,用于产生psel_m

用clk_m的pready产生ack_m,将ack_m同步到clk_s用于产生ack_s,用ack_s清req_s

在clk_m等待req_s2m拉低,这个时候clk_s和clk_m才算完成双向握手,一次apb传输完成。这里和脉冲同步时一个道理。

具体代码可以参考另一篇私人博客

apb2apb的asyncBridgeicon-default.png?t=N7T8https://blog.csdn.net/cy413026/article/details/128960805?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22128960805%22%2C%22source%22%3A%22cy413026%22%7D

当然这篇参考文档给的apbAsyncBridge的写法和coreSight中的写法实际是一致的。

coreSight说明可参考:

jtag2axi和coresight学习_cy413026的博客-CSDN博客

4.其他AXI/AHB的桥在异步处理上类似于apb2apb的异步桥

  • 4
    点赞
  • 69
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值