信雅纳400/800G网络测试仪之 CDF/ Extended Payload 功能:完全用户自定义的协议报文支持/可编程的协议内容支持

Note# 2024-3-21

今天被一个做芯片测试的客户追着问,应该合作在测试仪上做完全自定义的报文,添加自己的私有协议进去,他觉得每次都导入报头太麻烦了,然后就看了下Application Note关于CDF功能的描述,照着机翻的版本来回看了看,好像是有点意思。

场景需求:可自由编程/自定义的测试数据封包


在以太网通信产品研发过程中,灵活生成测试数据封包的能力是很有必要的,如测试验证 NPU(Network Processor Unit)需要用户能够对数据封包中的每个字节进行可编程/自定义控制。

NPU 可用于Switch、Router、Firewall、DPI等通信网络设备中,其在设备中承担任务包含:
- 识别区分数据封包中的每个比特字符
- 路由信息表查询
- 根据需要更改数据包中的某字段
- 管理队列和缓冲区

在开发过程中,必须验证 NPU 不仅在处理预期数据包时具有可预测的行为,而且在异常数据包到达 NPU 时也具有可预测的行为,开发过程还可能涉及需要 NPU 执行特定操作的新协议报文格式。可自由编程的测试数据封包功能将帮助开发人员生成测试流量,从而评估异常数据封包、新协议报文格式和其他流量条件下对设备的影响。同样的其他设通信设备的开发也会需要可自由编程的测试数据封包。


信雅纳:CDF(Custom Data Field )/自定义数据字段


自定义数据字段(CDF)已在新Odin-10G,Loki-100G,Thor-400G,Freya-800G上做支持。

它允许为测试流量Streams定义一系列自定义数据字段

  • 每个 CDF 将按照Streams中定义的顺序作为独立的测试数据封包发送
  • 每个CDF 可以设定不同的长度大小和不同的内容
  • 每个CDF 可按照为数据流指定的偏移值插入到测试数据包


如果为数据流指定了一组协议报文头(Protocol Header Segment),且 CDF 偏移值位于报文头所占区域内,则 CDF 数据可能会覆盖掉协议报文头数据。如果偏移量为 0,CDF 将覆盖为测试数据包定义的所有协议报文头。如果将偏移量设为 0,同时禁用帧校验序列(FCS)和仪表标签跟踪数据(TPLD)字段,则可以自由编程测试数据包中的所有字节。如何禁用 FCS 和 TPLD 将在后续说明。


每个测试端口的 CDF内存被分成 CDF 小块,每个小块包含一个CDF。数据块的大小对数据流中的所有 CDF 都是相同的,并且尺寸适合最大的 CDF。块大小为 2的n次方字节,范围从 64 字节到端口的最大传输单元 (MTU)。如果 CDF 短于数据块大小,数据块的剩余部分将用系统自动填充,自动填充的内容在数据流属性面板的 "Payload Content "部分定义为 "Payload Type"。

如果上面一段机翻的很拗口,可以总结为以下内容

Protocol Header 与Payload本质是一样的,所以定义了CDF字段,如果没有加Offset偏移量,将是会替换掉之前设定Segment/Protocol Header.

默认测试仪会计算加上FCS/CRC校验和在最后面,以及加入TPLD标签(用以追踪区分是否为仪表的发出的数据包),想发送完全自定义的报文,需要禁用掉FCS & TPLD.


图 2 展示了以数据流形式发送的测试数据包,该数据包定义了两个覆盖部分 MAC 标头的 CDF。每个 CDF 都作为单独的测试数据包发送。对于数据流中定义的测试数据包,偏移和协议报头是通用的。如果需要在每个测试数据包中显示数据包头,偏移量必须至少设置为数据包头部分的长度。如果需要对偏移和协议标头进行不同的定义,则必须在单独的数据流中定义 CDF。

信雅纳CDF自定义数据段内容
图 2:使用两个 CDF 覆盖部分 MAC 标头的数据流定义
测试数据包的总长度在数据流属性面板的 "数据包内容 "部分定义(见图 5)。
- 如果测试数据包的总长度大于偏移 + CDF 块 + PTLD + FCS 的大小,则会在 CDF 块和 TPLD 之间添加填充 - 图 2 显示了两个测试数据包,其中在实际 CDF 之后和 CDF 块之后都添加了填充。
- 如果测试数据包的总长度短于偏移 + CDF 块 + PTLD + FCS 的大小,则会从 CDF 块的末端(即填充可能所在的位置)切下 CDF 块,使其与测试数据包相匹配。
- 如果 CDF 数据偏移设置在协议标头段结束后的位置,则在协议标头和 CDF 之间添加填充(见图 3)。

信雅纳NPU芯片测试
图 3:带有一个 CDF 的测试数据包,从协议标头(此处为 MAC 标头)后 10 个字节开始

启用 CDF 功能


在父端口属性面板(见图 4)的 "Custom Data Field "字段中选择 "Payload mode",即可启用 CDF 功能。这将启用该端口上所有数据流的功能。

图 4:有效负载模式字段


定义数据包总大小和填充


在数据流属性面板的数据包内容部分,可以定义与 CDF 相关的几个参数:
- 数据包大小类型
- 指定数据流中测试数据包总长度的信息
- 有效载荷类型(Payload Type),定义测试数据包中 CDF 块前后和内部可能使用的填充。

图 5:所选有效载荷类型将用作填充

配置 CDF


如图 6 所示,在数据流的父端口上启用 CDF 功能后,数据流属性页面中将启用新的自定义数据字段部分。


图 6:CDF 配置
单击添加另一个 CDF。添加新的 CDF 时,需要定义其长度。以后可以通过点击 。
数据流中 CDF 的偏移量(即数据包的起点)在 "字段偏移量 "字段中设置。
在 "字段数据值 "中输入所需的 CDF 内容。


禁用 FCS


在数据流属性面板的 "错误处理 "部分取消选中 "插入帧校验和(FCS)"复选框,就可以从测试数据包中省略帧校验序列(FCS)。

图 7:数据流属性面板的 "错误处理 "部分


禁用 TPLD


在标准 Xena 测试数据包的末尾,默认添加了一个特殊的专有数据区,称为仪表追踪标签数据(TPLD)(见图 2、图 3 和图 12)。TPLD 包含数据包的各种信息,允许 Xena 测试仪检测数据包丢失或排序错误等异常情况,并测量以太网链路上的延迟和数据包抖动。启用 CDF 功能后,您可能需要从传输流中的测试数据包中移除 TPLD,以便完全控制数据包的内容。

创建数据流时,将为该数据流分配一个数据流编号和一个测试有效载荷 ID (TID),用于标识 TPLD。如果如图 8 所示移除测试有效载荷 ID,则 TPLD 将被省略。

图 8:数据流属性面板的标识部分
自由编程测试数据包的六个步骤
总结:要启用可自由编程的测试数据包,即用户可以在支持 CDF 的 测试板卡模块上定义数据包的所有字节,必须执行以下步骤:
1. 激活测试端口上的 CDF 功能(见图 4)
2. 设置数据包大小,使其与所需测试数据包的长度完全匹配(见图 5) 3.
3. 将偏移设置为 0(见图 6)
4. 将所需内容输入 CDF(见图 6) 5.
5. 禁用 FCS(见图 7)
6. 禁用 TPLD(见图 8)
如果需要不同大小的 CDF 且不想添加填充,则必须为每种 CDF 大小定义一个新的数据流。


数据包顺序


默认情况下,数据流被独立处理,并合并为端口的综合流量模式,同时考虑为每个数据流定义的传输配置文件(见图 10,正常端口 TX 模式)。


图 9:数据流属性面板的识别部分
如果将父端口属性面板中的端口 TX 模式设置为顺序(图 9),则可以顺序发送测试数据包: 每个数据流依次发送一个或多个数据包,然后以循环模式继续发送到下一个数据流。数据流的数据包数量输入该数据流传输配置文件中的 Seq.Packets 字段(见图 10,顺序 TX 模式)。单个数据流的传输速率将被忽略;总体传输速率由传输配置文件部分的端口级别决定(图 9)。考虑到数据包长度和数量,这反过来又决定了每个数据流的速率。一个周期内的最大数据包数(即所有启用数据流的 Seq.Packets 之和)为 500。

正常端口传输模式(默认) 顺序传输模式

以下解释的是端口的调度模式与流的调度模式


图 10:数据流传输配置文件定义
- 如果 Seq.Packets 字段中的数字与数据流中的 CDF 数量一致,则先发送该数据流中的所有 CDF,然后再发送下一个数据流中的 CDF。
- 如果 Seq.Packets 数量高于数据流中的 CDF 数量,则重复发送该数据流中的 CDF,直到达到 Seq.Packets 数量;然后发送下一个数据流中的 CDF。
- 如果 Seq.Packets 数量少于数据流中的 CDF 数量,则在可以发送数据流中的 CDF 时,按数据流中定义的顺序发送该数量的 CDF。
图 11 展示了 Seq.Packets 的不同设置对流量模式的影响。在所有示例中,为数据流 1 定义了两个 CDF,而为数据流 0、2 和 3 定义了一个 CDF。

图 11:不同 Seq.Packets 设置下的顺序测试数据包流量示例
CDF 规格
CDF 功能可用的总面积取决于测试模块类型和端口配置。
每个 100G 端口的基本 CDF 规格:
- 最大 CDF 数量: 4096
- 最大 CDF 大小: 端口的 MTU。
- 最大 CDF 偏移量 = 2032
- 最大 CDF 内存:262144 字节(256 k字节)
端口的 MTU 可以在端口属性面板的端口功能部分找到,即 "最大数据包长度"(请注意,不同数据速率的端口可能有不同的 MTU):


图 13:最大数据包长度(字节)是端口的 MTU(本例中为 12288 字节)
未来版本的 M1QSFP28SFP28 测试模块在 100G 时将支持以下功能:
- 最大 CDF 数量: 14336
- 最大 CDF 大小: 端口的 MTU。
- 最大 CDF 偏移量 = 2032
- 最大 CDF 内存:917504 字节(892 千字节)
当模块以较低的端口速度运行时,各端口共享上述 CDF 内存和每个端口的最大 CDF 数量,具体如下:
每个端口的 CDF 内存:
- 40G/50G 端口: 最大 100G CDF 内存/2
- 25G 端口: 最大 100G CDF 内存 / 4
- 10G 端口: 最大 100G CDF 内存 / 8
每个端口的最大 CDF 数量:
- 40G/50G 端口: 最大 100G CDF 数量 / 2
- 25G 端口: 最大 100G CDF 数量 / 4
- 10G 端口: 最大 100G CDF 数量 / 8

CDF 内存分配


单个数据流使用的 CDF 内存量分三步计算:
1. 计算 CDF 大小
CDF 的大小由其包含的数据字节数及其在数据包中的偏移量组合而成。计算公式如下
CDF 大小 = datasize(字节数)+ (offsetbytes_value modulo 8)。
例如,偏移量为 3、数据大小为 234 字节的 CDF,其 CDF 大小为 237 字节;如果偏移量为 11,则 CDF 大小也为 237 字节(11 取 8 为 3)。
2. 计算 CDF 块内存大小
每个数据流的 CDF 内存被分割成若干块,每个块包含一个 CDF。CDF 块的大小对于数据流中的所有 CDF 都是相同的,长度为 2n 字节,尺寸为适合最大 CDF 的大小(见步骤 1)。
(见步骤 1)。数据块大小的范围从 64 字节到端口的 MTU。
举个例子: 如果为数据流定义的最大 CDF 条目为 237 字节,则数据块大小为 256 字节。因此,该数据流的所有 CDF 都将使用 256 字节内存,而不考虑它们各自的大小。
3. 计算单个数据流的 CDF 内存使用量
根据上述两个步骤,计算单个数据流的 CDF 内存使用量的公式为
数据流 CDF 内存使用量 = CDF_memory_block_size *_of_CDFs 数量 
因此,如果上述示例中描述的数据流有 500 个 CDF,则该数据流使用的 CDF 内存总量为:256 字节 * 500 = 128000 字节。


信雅纳:Extended Payload/扩展有效载荷


扩展有效载荷功能是 Xena Networks 高速测试模块的另一项功能。扩展有效载荷允许用户定义很长的有效载荷。扩展有效载荷将占据测试数据包中紧随协议头部分之后的整个有效载荷字段。
启用扩展有效载荷功能
在父端口面板的 "有效载荷模式 "字段中选择 "扩展有效载荷",即可启用扩展有效载荷功能(见图 4)。这将启用该端口上所有数据流的功能。


配置扩展有效负载


启用扩展有效载荷后,就可以在 "扩展有效载荷大小 "字段中为图 14 所示的数据流设置所需的数据包内容区域大小。但请注意,测试数据包的总大小(也在图 14 中定义)必须小于为数据流定义的协议头大小 + 扩展有效载荷 + TPLD + FCS。
- 如果数据包总大小小于此值,扩展有效载荷将被剪切以适应测试数据包。
- 如果数据包较长,将在扩展有效载荷和 TPLD 之间插入衬垫

图 14:设置扩展有效载荷大小


图 15:流协议标头编辑器
如图 15 所示,设置好大小后,流协议标头编辑器中就会出现相应的数据区。用户可以在数据区填入所需的内容。
与 CDF 一样,扩展有效载荷也被填入一个长度为 2n 字节的数据块中。块的大小从 64 字节到端口的 MTU 不等;扩展有效载荷适合的最小大小被使用。扩展有效载荷未使用的数据块中的字节会像 CDF 数据块一样被填充。


图 16 展示了一个测试数据包,在 166 字节的测试数据包中包含 120 字节的扩展有效载荷。对于图 16 中的测试数据包,这意味着扩展有效载荷和扩展有效载荷占用的内存块中剩余的 8 个字节有足够的空间。
图 16:带有 120 字节扩展有效载荷的测试数据包

禁用 FCS 和 TPLD


如图 7 和图 8 所示,对于 CDF,可在带有扩展有效载荷的测试数据包中省略 FCS 和 TPLD。
 

扩展有效载荷内存分配

扩展有效载荷功能是 CDF 功能的一种特殊应用,其偏移量与测试包中的标头相匹配。因此,有关 CDF 规范和 CDF 内存分配的章节也适用于扩展有效载荷功能。


修改器/Modifers/字段跳变

可以在扩展有效载荷区域设置修改器,就像在普通协议字段中设置修改器一样。
修改器不能在 CDF 上设置,因为该功能本身可被视为具有与修改器选项相同的某些特性,但规模要大得多。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/280972.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

D55125ADA A型漏电保护芯片,适用于 110V⁓220V(50/60Hz)电压,可应用于 新能源充电桩(充电枪)、智能空开(智能微断开关)等工业产品

一、应用领域 新能源充电桩(充电枪)、智能空开(智能微断开关)等工业产品,以及电热水器、电烤箱、电烤炉等小家电产品。 二、功能介绍 D55125ADA 是一款高性能 CMOS 漏电保护器专用电路。芯片内部包含稳压电源、放大电路…

IP 协议的相关特性

1.IP协议的特性 无连接性。IP协议是一种无连接协议,这意味着数据包在传输过程中不需要保留连接状态信息。每个数据包都是独立发送和处理的,每个包都可以按不同的路径传输到目的地。 不可靠性。IP协议不提供任何可靠性保证,数据包在传输过程…

设计模式 模板方法模式

01.如果接到一个任务,要求设计不同型号的悍马车 02.设计一个悍马车的抽象类(模具,车模) public abstract class HummerModel {/** 首先,这个模型要能够被发动起来,别管是手摇发动,还是电力发动…

鸿蒙Harmony应用开发—ArkTS-全局UI方法(列表选择弹窗)

列表弹窗。 说明: 从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 本模块功能依赖UI的执行上下文,不可在UI上下文不明确的地方使用,参见UIContext说明。 从API version 10开始&#xff0…

什么是VR应急预案演练虚拟化|VR体验馆加盟|元宇宙文旅

VR 应急预案演练虚拟化指的是利用虚拟现实(Virtual Reality,VR)技术进行应急预案演练的过程。在传统的应急预案演练中,人们通常需要在实际场地或模拟环境中进行演练,这可能存在一些限制,如成本高昂、场地受…

C语言每日一题06

一、题目 二、解析 void main () { char c1,c2; int a1,a2; c1 getchar ();//读取第一个输入,c11 scanf (“%3d”,&a1&#xff…

MNN createSession 之创建流水线后端(四)

系列文章目录 MNN createFromBuffer(一) MNN createRuntime(二) MNN createSession 之 Schedule(三) MNN createSession 之创建流水线后端(四) MNN Session 之维度计算(五…

CSS学习(2)-盒子模型

1. CSS 长度单位 px :像素。em :相对元素 font-size 的倍数。rem :相对根字体大小,html标签就是根。% :相对父元素计算。 注意: CSS 中设置长度,必须加单位,否则样式无效&#xff…

19---时钟电路设计

视频链接 时钟硬件电路设计01_哔哩哔哩_bilibili 时钟电路设计 晶振是数字电路的心脏,数字电路需要一个稳定的工作时钟信号,时钟电路至关重要! 1、晶振概述 晶振一般指晶体振荡器。晶体振荡器是指从一块石英晶体上按一定方位角切下薄片&…

python课后习题一

题目: 1. 2. 解题过程: 1. """计算年数和天数""" minute int(input("请输入分钟数:")) hours minute // 60 days hours // 24 years days // 365 last_days days % 365 print(f"{minut…

kafka集群介绍及搭建

介绍 kafka是一个高性能、低延迟、分布式的消息传递系统,特点在于实时处理数据。集群由多个成员节点broker组成,每个节点都可以独立处理消息传递和存储任务。 路由策略 发布消息由key、value组成,真正的消息是value,key是标识路…

使用Pygame做一个乒乓球游戏

项目介绍 使用Pygame做一个乒乓球游戏。左侧为电脑,右侧为玩家。 视频地址-YT 视频搬运-B站 视频教程约90分钟。 代码地址 环境:需要pygame库,可用pip安装:pip install pygame 1. 基础版本 首先进行一些初始化,初始…

PHP全新美化广告横幅在线制作源码

源码简介 可以做网站的引流不需要安装上传就可以使用,在第一版基础上做了二次开发更加好用 注意:主机和服务器均可架设搭建,如果使用宝塔架设点击访问的时候提示找不到文件路径的时候,记得点击网站目录把防跨站攻击先关闭,这样就可以正常访问了,这款是…

海格里斯HEGERLS托盘搬运机器人四向车引领三维空间集群设备柔性运维

随着市场的不断迅猛发展变化,在物流仓储中,无论是国内还是海外,都对托盘式解决方案需求量很大。顾名思义,托盘式解决方案简单理解就是将产品放置在托盘上进行存储、搬运和拣选。 面对托盘式方案需求,行业中常见的方案是…

如何在CentOS搭建docker compose ui可视化工具并无公网IP远程管理容器

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

【C++ leetcode】双指针问题(续)

3. 202 .快乐数 题目 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为: 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。如果这个过程 结…

node.js快速入门-day03

个人名片: 😊作者简介:一名大二在校生 🤡 个人主页:坠入暮云间x 🐼座右铭:给自己一个梦想,给世界一个惊喜。 🎅**学习目标: 坚持每一次的学习打卡 文章目录 web服务器创建…

JavaScript高级(十三)---ES6中Set,map

ES6 Set 在ES6之前,我们存储数据的结构主要有两种:数组、对象。 在ES6中新增了另外两种数据结构:Set、Map,以及它们的另外形式WeakSet、WeakMap。 Set是一个新增的数据结构,可以用来保存数据,类似于数组&a…

[隐私计算实训营学习笔记] 第1讲 数据要素流通

信任四基石 数据的分级分类 技术信任:全链路审计、闭环完成的数据可信流通体系 技术信任:开启数据密态时代 数据可流通的基础设施:密态天空计算

供需平衡对电子元器件价格的影响

随着科技的迅猛发展和智能化产品的普及,电子元器件已经成为现代社会不可或缺的一部分。从手机到汽车,从家用电器到工业机械,无处不在的电子元器件都在支撑着我们的生活和工作。然而,电子元器件市场的供需平衡却经常面临挑战&#…