0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Ack/Nak机制详细介绍

SwM2_ChinaAET 来源:未知 作者:胡薇 2018-05-29 14:46 次阅读

Ack/Nak是一种由硬件实现的,完全自动的机制,目的是保证TLP有效可靠地传输。Ack DLLP用于确认TLP被成功接收,Nak DLLP则用于表明TLP传输中遇到了错误。

如上图所示,发送方会对每一个TLP在Replay Buffer中做备份,直到其接收到来自接收方的Ack DLLP,确认该DLP已经成功的被接受,才会删除这个备份。如果接收方发现TLP存在错误,则会向发送发发送Nak DLLP,然后发送方会从Replay Buffer中取出数据,重新发送该TLP。

Ack/Nak机制内部的详细结构图如下图所示:

下面对图中的各个Elements分别做一个简单地介绍。

首先是发送端的Elements:

来个大图特写:

NEXT_TRANSMIT_SEQ Counter

NEXT_TRANSMIT_SEQ Counter,即NTS计数器,是一个12位的计数器。当数据链路层处于DL-Down状态或者复位时,该计数器会被初始化为0。该计数器只会执行加一操作,也就是说当其到达最大值4095时,在进行加一操作则会变成0(Roll Over)。该计数器用于产生下一个待发送的TLP的序列号(Sequence Number)。每一个序列号都是与一个TLP所唯一对应的,可以说这个序列号正是整个Ack/Nak机制的关键。

LCRC Generator

LCRC产生器用于产生一个32位的CRC值,其作用于整个TLP和其对应的序列号。

Replay Buffer

Replay Buffer是Mindshare书中的叫法,在PCIe Spec中,这个Buffer的名称叫做Retry Buffer。Replay Buffer中按照传输顺序,存储了整个TLP、序列号和LCRC,如下图所示:

当发送端收到来自接收端的Ack DLLP时,会将Buffer中相应的TLP(包括对应的序列号和LCRC)移除;如果接收到的是Nak DLLP,则会将Buffer中响应的TLP(包括对应的序列号和LCRC)重新发送给接收端。

REPLAY_TIMER Count

REPLAY_TIMER是一种看门狗定时器,当该定时器溢出,则表明发送端已经发送了一个或者多个TLP,但是并未收到来自接收端的应答信号(Ack/Nak)。此时,发送端会将Replay Buffer中的TLP重新发送,并将看门狗定时器重启。

只要发送端发送了任何TLP,该定时器便会启动,在接收到来自接收端的应答信号之前都会持续地运行。当收到应答信号之后,定时器会立即被清零。此时如果Replay Buffer仍然有TLP(表明还有TLP被发送,但是仍未得到应答),定时器又会被立即被重新启动。如果Buffer中是空的,则定时器不会被重新启动,直到新的TLP被发送。

REPLAY_NUM Count

这是一个2位的计数器,用于记录同一个TLP发送失败的次数,当其值从11b变为00b时(溢出了,表示尝试发送某个TLP失败了4次),数据链路层会自动地强制物理层重新进行链路训练(即LTSSM进入Recovery状态)。当完成链路训练之后,便会重新发送之前发送失败的TLP。

当发送端接收到来自接收端的Nak DLLP或者发送端的看门狗定时器(REPLAY_TIMER)溢出时,该计数器都会被加一;当接收到Ack DLLP时,该计数器则会被清零。

ACKD_SEQ

ACKD_SEQ寄存器用于存储最近接收到的Ack或者Nak DLLP中的序列号。当复位或者数据链路层处于无效状态时,该寄存器会被初始化为全1。关于ACKD_SEQ寄存器的具体用法会在后续的文章中,用例子的形式详细说明。

DLLP CRC Check

接收端在接收到来自发送端的DLLP后,首先会检查其DLLP CRC,如果发现有错误,则会直接将其丢弃,认为其实无效的DLLP。

然后是接收端的Elements:

首先来一张大图特写:

LCRC Error Check

顾名思义,LCRC Error Check用于检查接收到的TLP是否存在错误。如果存在错误,则将对应的TLP直接丢弃,然后产生一个Nak DLLP发送给发送端,让其重新发送该TLP。

NEXT_RCV_SEQ

NEXT_RCV_SEQ是一个12位的计数器,即Next Receive Sequence Number,其值为已经成功接收的TLP的序列号加1。主要用于检查当前接收到的TLP是不是应该接收到的TLP。

如果NEXT_RCV_SEQ和当前接收到的TLP中的序列号的值相等,则认为这是一个有效的TLP,但是接收端并不会立即向发送端发送Ack DLLP,而是等到AckNak_LATENCY_TIMER溢出时才向发送端发送Ack DLLP。也就是说,一个Ack DLLP可能会对应多个TLP,接收端不会每成功接收到一个TLP便向发送端发送Ack DLLP。

如果当前接收到的TLP中的序列号小于NEXT_RCV_SEQ(且差值不超过2048),则认为该TLP之前已经成功发送过了,此次是重复发送。需要注意的是,PCIe Spec认为重复发送并不是一个错误,只是直接将该TLP丢弃,并没有Nak或者Error Reporting,但是会返回一个包含有上一次成功接收的TLP的序列号(NRS-1)的Ack DLLP给发送端。

如果当前接收到的TLP的序列号大于NEXT_RCV_SEQ,表明传输过程中漏掉了一些TLP。此时,接收端会返回Nak DLLP,并直接丢弃该TLP。

一个简单的例子如下图所示:

NAK_SCHEDULED Flag

NAK_SCHEDULED是一个标志位,当接收端产生Nak DLLP时,该标志位会被置位。当接收端成功接收到有效的TLP时,该标志位会被清零。需要特别注意的是,当该标志位处于置位状态时,接收端不应产生其他的Nak DLLP。

AckNak_LATENCY_TIMER

AckNak_LATENCY_TIMER定时器会在接收端成功接收到有效的TLP,且并未向发送端返回Ack DLLP之前运行。当AckNak_LATENCY_TIMER定时器溢出时,接收端会立即向发送端返回Ack DLLP(携带的序列号为NRS-1,即一个Ack对应多个有效的TLP)。无论接收端返回Ack还是Nak,该定时器都会被复位,但是只有当接收端再次收到有效的TLP时,该定时器才会被重新启动。

该定时器(REPLAY_TIMER)的值是由PCIe Spec规定的和Lane的数量与Max_Payload有关,Gen1的值如下图所示:

Gen2(5GT/s)如下图所示:

注:该定时器(REPLAY_TIMER)的值是AckNak_LATENCY_TIMER定时器值的三倍。

Ack/Nak Generator

显然,Ack/Nak Generator的功能是产生Ack或者Nak DLLP。其格式如下:

最后,介绍一下PCIe Spec中推荐的包优先级顺序。我们知道,PCIe总线通信中,存在多种类型的包,包括TLP、DLLP和Ordered Sets等。为了能够是总线达到最优的传输效率,PCIe Spec推荐对这些包的优先级做如下的设置:(当然这只是推荐,并没有强制厂商一定要这要去实现)。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • ACK
    ACK
    +关注

    关注

    0

    文章

    28

    浏览量

    11153
  • PCIe
    +关注

    关注

    15

    文章

    1241

    浏览量

    82725
  • NAK
    NAK
    +关注

    关注

    0

    文章

    4

    浏览量

    3732

原文标题:【博文连载】PCIe扫盲——Ack/Nak 机制详解(一)

文章出处:【微信号:ChinaAET,微信公众号:电子技术应用ChinaAET】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    CY7C65215A作为从站,在主站写入时响应NAK是怎么回事?

    设备写入数据时,总是在主设备向从设备写入的每个字节上响应 ACK。 我遇到的问题是,当我的微控制器作为主站向作为从站的赛普拉斯写入数据时,赛普拉斯对最后一个字节的响应是 NAK,而不是 ACK
    发表于 07-04 06:30

    BLE中的ACK机制

    ACK
    橙群微电子
    发布于 :2023年03月31日 09:52:36

    请问CC2530如何实现指定节点的ACK回复功能?

    ,节点和接收器都出在一个频点下。CC2530的相关机制是否能实现这点呢?麻烦在于auto ack是自动回复的,似乎不能规定目标地址!
    发表于 04-24 08:58

    【每日一知识点】在STM32F4上OTG 主机库在 BULK 传输上对 NAK 的处理

    数据后,不再回复 NAK 握手,而是回复主机要获取的数据,然后主机硬件回复 ACK 来结束本次 transfer。BULK IN通道对 NAK的处理和 CTRL IN通道对 NAK的处
    发表于 06-02 15:22

    ACK威廉希尔官方网站 图

    ACK威廉希尔官方网站 图
    发表于 01-01 05:36 1350次阅读
    <b class='flag-5'>ACK</b>威廉希尔官方网站
图

    什么是ACK (ACKnowledge Character)

    什么是ACK (ACKnowledge Character)  英文缩写: ACK (ACKnowledge Character) 中文译名: 确认字符 分  类: 传输与接入
    发表于 02-22 10:12 1839次阅读

    PCIe总线的通信机制

    那么为什么要分为Non-Posted和Posted两种类型呢?对于Memory Writes来说,对效率要求较高,因此采用了Posted的方式。但是这并不意味着Posted类型的操作不需要Completer进行应答,只是此时Completer采用了另一种应答机制——Ack
    的头像 发表于 04-24 09:41 1.2w次阅读
    PCIe总线的通信<b class='flag-5'>机制</b>

    简单地分析几个Ack/Nak机制的例子

    设备B接收到了TLP4095,但是该TLP并未通过CRC校检(即存在错误)。此时无论AckNak_LATENCY_TIMER处于何种状态,设备B都会立即向设备A返回Ack4094(注意返回的Ack
    的头像 发表于 05-30 09:16 6404次阅读
    简单地分析几个<b class='flag-5'>Ack</b>/<b class='flag-5'>Nak</b><b class='flag-5'>机制</b>的例子

    发动机制造工艺的详细资料说明

    本文档的主要内容详细介绍的是拖拉机的发动机制造工艺详细资料说明。
    发表于 04-09 08:00 0次下载
    发动<b class='flag-5'>机制</b>造工艺的<b class='flag-5'>详细</b>资料说明

    C0603X5R226M6R3NAK 片式高容多层陶瓷电容器

    电子发烧友网为你提供EYANG(EYANG)C0603X5R226M6R3NAK相关产品参数、数据手册,更有C0603X5R226M6R3NAK的引脚图、接线图、封装手册、中文资料、英文资料,C0603X5R226M6R3NAK
    发表于 01-29 11:04

    C0603X5R226X6R3NAK 片式高容多层陶瓷电容器

    电子发烧友网为你提供EYANG(EYANG)C0603X5R226X6R3NAK相关产品参数、数据手册,更有C0603X5R226X6R3NAK的引脚图、接线图、封装手册、中文资料、英文资料,C0603X5R226X6R3NAK
    发表于 03-17 19:41

    ack文本查找工具

    ./oschina_soft/ack3.zip
    发表于 05-25 09:24 0次下载
    <b class='flag-5'>ack</b>文本查找工具

    PCIe链路层里的ACK/NAK介绍

    Spec洋洋洒洒数千页,也不会从头到尾去通读整个协议。对于cocotbext-pcie里面牵涉到的链路层的ACK/NAK,牵涉到的PCIe背景,聊做记录。     本文仅结合PCIe Spce
    的头像 发表于 06-25 10:31 2909次阅读
    PCIe链路层里的<b class='flag-5'>ACK</b>/<b class='flag-5'>NAK</b><b class='flag-5'>介绍</b>

    详细介绍​注意力机制中的掩码

    注意力机制的掩码允许我们发送不同长度的批次数据一次性的发送到transformer中。在代码中是通过将所有序列填充到相同的长度,然后使用“attention_mask”张量来识别哪些令牌是填充的来做到这一点,本文将详细介绍这个掩
    的头像 发表于 07-17 16:46 707次阅读
    <b class='flag-5'>详细</b><b class='flag-5'>介绍</b>​注意力<b class='flag-5'>机制</b>中的掩码

    CAN总线波形中为什么ACK电平偏高?

    在观察CAN通信波形时,我们会发现差分电平在ACK段突然增高,这是什么原因导致的呢?本文结合测试实例对ACK电平偏高的原因做简单分析。ACK简介ACK的作用:确认一帧报文是否正常接收。
    的头像 发表于 03-28 08:23 1212次阅读
    CAN总线波形中为什么<b class='flag-5'>ACK</b>电平偏高?