PCI Express学习篇---链路层(二)ACK/NAK实例

2024-03-15 00:30

本文主要是介绍PCI Express学习篇---链路层(二)ACK/NAK实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

声明:此文章为原创,转载请注明 转自https://blog.csdn.net/weixin_48180416/article/details/117396394

以下为收到ACK/NAK的例子,详细原理介绍请见上一篇博文。


  • Device A发送Seq=3,4,5,6,7的包,Device B接收到Seq=3,4,5 good TLP后,NRS为6;
  • 当接收到seq=3的TLP时,AckNak_LATENCY_TIMER开始计数;
  • 当接收到完seq=4,5的TLP后,AckNak_LATENCY_TIMER expire;
  • Device B发送seq=5即NRS-1的ACK包,AckNak_LATENCY_TIMER清零,但是当收到seq=6的TLP才会重新开始计数;
  • Device A收到ACK包,清除Replay timer and Replay num,清除replay buffer里面小于等于5的TLP包

  • Device A发送Seq=4094,4095,0,1,2的包,Device B接收到Seq=4094,4095,0,1 good TLP后,NRS为2;
  • 当接收到seq=4094的TLP时,AckNak_LATENCY_TIMER开始计数;
  • 当接收到完seq=4095,0,1的TLP后,AckNak_LATENCY_TIMER expire;
  • Device B发送seq=1即NRS-1的ACK包,AckNak_LATENCY_TIMER清零,但是当收到seq=2的TLP才会重新开始计数;
  • Device A收到ACK包,清除Replay timer and Replay num,清除replay buffer里面4094,4095,0,1的TLP包。

  • Device A发送Seq=4094,4095,0,1,2的包,Device B接收到Seq=4094没有错误,Seq=4095有LCRC错误,NRS=4095
  • 当接收到seq=4094的TLP时,AckNak_LATENCY_TIMER开始计数;
  • 当接收到完seq=4095的TLP后,立刻将NAK_SCHEDULED flag置为1,发送Seq=4094的NAK包(即NRS-1);
  • Device B发送NAK时AckNak_LATENCY_TIMER清零并且停止计数;
  • Device B收到的Seq=0,1,2的尽管可能是good TLP也会丢弃(因为所有的TLP必须是in-order的),并且不会再发送NAK了,因为NAK_SCHEDULED flag=1
  • Device A收到Seq=4094的NAK,将REPLAY_TIMER和REPLAY_NUM清零,清除replay buffer中Seq=4094及之前的TLP,然后重放Seq=4095,0,1,2的包,重新计数REPLAY_TIMER并且将REPLAY_NUM+1;
  • Device B收到Seq=4095的重放包为good TLP,会清除NAK_SCHEDULED flag,重新启动AckNak_LATENCY_TIMER并且将NRS+1。

  • Device A发送Seq=4094,4095,0,1,2的包,Device B接收到Seq=4094,4095,0没有错误,NRS=1
  • 当接收到seq=4094的TLP时,AckNak_LATENCY_TIMER开始计数;
  • 当接收到完seq=4095,0的TLP后,AckNak_LATENCY_TIMER expire;
  • Device B发送seq=0即NRS-1的ACK包,AckNak_LATENCY_TIMER清零,但是当收到seq=2的TLP才会重新开始计数;
  • Device A收到ACK包,清除Replay timer and Replay num,清除replay buffer里面4094,4095,0的TLP包;
  • Seq=1的TLP Lost(也许是物理层发生问题丢包),Seq=2的TLP到达Device B,Seq Num>NRS,Device B丢弃Seq=2的包,立刻将NAK_SCHEDULED flag置为1,发送Seq=0的NAK包(即NRS-1);
  • Device A收到NAK包,清除Seq=0及之前的包(已经由ACK清除)重放Seq=1,2的包;
  • Device B接收重放的Seq=1,2的包,如果没有error就传递给事务层。

Handing Bad ACK

如果Seq=2的ACK Lost或损坏,REPLAY_TIMER可能会超时使整个replay buffer重放,Device B这个时候如果接收到Seq=4094,4095,0,1,2的包就会认为是Duplicate,会丢弃并重新发送一个Seq=2 (即NRS-1)的ACK包。

Handing Bad NAK

如果Seq=2的NAK Lost或损坏,REPLAY_TIMER可能会超时使整个replay buffer重放,Device B这个时候如果接收到Seq=4094,4095,0,1,2的包就会认为是Duplicate,会丢弃并重新发送一个Seq=2 (即NRS-1)的ACK包。

一旦Seq=3的包被Device B成功接收,会清除NAK_SCHEDULED flag,增加NRS到4,重新启动AckNak_LATENCY_TIMER。

 

 

 

 

这篇关于PCI Express学习篇---链路层(二)ACK/NAK实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/810218

相关文章

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

Java Stream流以及常用方法操作实例

《JavaStream流以及常用方法操作实例》Stream是对Java中集合的一种增强方式,使用它可以将集合的处理过程变得更加简洁、高效和易读,:本文主要介绍JavaStream流以及常用方法... 目录一、Stream流是什么?二、stream的操作2.1、stream流创建2.2、stream的使用2.

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

Python跨文件实例化、跨文件调用及导入库示例代码

《Python跨文件实例化、跨文件调用及导入库示例代码》在Python开发过程中,经常会遇到需要在一个工程中调用另一个工程的Python文件的情况,:本文主要介绍Python跨文件实例化、跨文件调... 目录1. 核心对比表格(完整汇总)1.1 自定义模块跨文件调用汇总表1.2 第三方库使用汇总表1.3 导

MySQL多实例管理如何在一台主机上运行多个mysql

《MySQL多实例管理如何在一台主机上运行多个mysql》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Apache Ignite缓存基本操作实例详解

《ApacheIgnite缓存基本操作实例详解》文章介绍了ApacheIgnite中IgniteCache的基本操作,涵盖缓存获取、动态创建、销毁、原子及条件更新、异步执行,强调线程池注意事项,避免... 目录一、获取缓存实例(Getting an Instance of a Cache)示例代码:二、动态

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA