pcie的ack/nak机制

当receiver接收到TLP之后,判断TLP是否完整,如果有错误,则返回ACK给发送端,如果正确的话,则返回ACK。

当发送端收到NAK,则通过retry buffer重发该TLP。如果收到ACK,则将该TLP从rery buffer中删掉。

需要注意的是,接收端在收到正确的TLP之后,不会马上发送ACK,而是要等一个叫ACKNAK_LATENCY_TIMER的计数器计数,计数到了之后才会发送ACK。在等待发送ACK的期间,接收端可能会收到多个TLP。如果计数到点的时候,收到了多个TLP,则只要发送带有最后TLP序号的ACK就行。发送端在接收到这个ACK之后,会将retry buffer中这个ACK序号对应的TLP以及小于这个序号的TLP全部清除。

注意NAK中的序号是上一个成功接收的TLP序号。存在这样的情况,就是在接收端收到一个错误TLP时,已经收到了多个正确的TLP,但由于timer的原因,还未返回ACK,这时接收端需要立刻返回带有最后一个正确TLP的NAK给发送端。发送端收到这个NAK后,会将retry buffer中对应序号及之前的TLP清理掉,并重发下一个序号的TLP。

转载于:https://www.cnblogs.com/lybinger/p/10763814.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值