TSN协议原理!看完这一篇就够了(1)——时钟同步IEEE802.1AS-2020

2024-03-25 20:28

本文主要是介绍TSN协议原理!看完这一篇就够了(1)——时钟同步IEEE802.1AS-2020,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

▎前言

在许多应用场景中,一个本地局域网中互联的设备集群需要共享同一个时间,以支持各设备的协同工作。例如:音频设备与视频设备的配合播放,雷达与摄像头的数据融合等;这样一个看似简单的域功能,细化成为各节点的需求就变得不那么简单了。想象一下,A和B节点的绝对时间不同——A此刻时间为09:00:00,B的时间为09:00:05;时间频率不同——标准时间经过了1分钟,A节点计时59秒,B节点计时61秒;如何实现各节点的时间矫正,我们今天要讲解的802.1AS协议就是用来实现以上提到的功能的。

▎协议目的-共享时间

TSN任务组(Time-Sensitive Networking Task Group)是IEEE 802.1 Working Group的一个组成部分,它的目的是在IEEE 802网络上提供确定性连接。我们可以把确定性连接这个概念简单理解为网络包传输的低延时,低抖动和无丢包;TSN在汽车控制,工业自动化,电力自动化等领域的应用通过协议簇实现,例如时间同步机制类协议802.1AS,冗余机制类协议802.1CB,服务质量类协议802.1Qbv,Qav,Qbu等和安全机制类协议802.1Qci。在IEEE 802.1DG草案中定义了汽车车内以太网的通信配置要求,时钟同步机制采用802.1AS。

提供确定性连接的关键是共享网络中各组件的时间。802.1AS协议用于满足音频,视频等时间敏感应用和时间敏感控制场景下的时间同步需求;网络配置的更新,网络组件的增加,去除或者故障都不应影响同步功能。为此,协议规定了时间同步模型的架构,同步方法,节点的介质无关子层,介质相关子层具体实现方法。花费大量篇幅解释专业名词并非文章的核心,我们专注于基本概念、同步原理和实现形式。

▎基本概念-gPTP域

在讲解802.1AS协议之前,需要简单介绍一下IEEE 1588协议。IEEE 1588定义了一种精确时间协议,被称为precision time protocol,PTP。802.1AS基于PTP提出了自己的同步模型,并称之为generalized precision time protocol,gPTP。

下图给出了一个时间感知网络拓扑图。在这个网络系统中,由于所有的设备都具有gPTP能力,因此这个网络是一个gPTP域。虽然系统中存在网桥,路由器,终端站等多种设备,对于gPTP域来说只有两类,PTP终端节点(PTP End Instance)和PTP中继节点(PTP Relay Instance)。

如果节点只与一个节点连接,那么这是一个终端节点,比如图中的end station;如果节点与多个节点连接,那么这是一个中继节点,比如下图中的bridge和router;时间同步的最终效果是,所有的节点都以图中与stratum 1时钟源相连的bridge作为时间基准,并不断修正自己的时间;这个时间基准被称为主时钟(Grandmaster Clock,GM)。

图片来源:IEEE 802.1AS 2020
当网络出现故障时,例如外网与本地网络连接中断,本地网络中的所有设备会重新选择一个主时钟设备,也就是下图中的end station(local GM),作为自己的参考对象。

图片来源:IEEE 802.1AS 2020

▎同步原理-延时和频率比值

gPTP域中的时间修正通过发送和接收特定报文实现。首先确定主时钟节点和时间同步生成树,然后该节点会沿生成树方向发送时间同步报文,中继节点转将报文转发至下游节点,最终实现将GM时钟信息传递给域内所有节点。在时间同步过程中,存在两类延时:

  • 转发延时:报文在中继节点中停留的时间。转发延时是中继节点的本地属性,易于计算;
  • 传播延时:报文在链路上传播的时间。传播延时取决于很多因素,例如介质相关属性和链路长度。当两类延时时间都已知,各个节点通过累计报文到达前的转发延时和传播延时便可得到同步时间。

因此我们需要考虑:①如何选择GM时钟?②如何测量报文在同步路径中的延时?
在这里插入图片描述

GM时钟选择

有两种方法可以选择一个gPTP域内的主时钟:

  • 最优主时钟算法(Best Master Clock Algorithm, BMCA)

    使用BMCA来确定gPTP域的GM节点,并以该节点为根构建时间同步生成树。各节点之间通过发送Announce报文来交换最佳主时钟选择信息,通过两两对比报文内容,系统最终收敛到唯一的主时钟。

  • 预定义端口状态

    强制配置一个节点作为GM,并构建以该节点为根的时间同步生成树。

在车载网络中,主时钟是预先分配的,例如将TBOX作为GM,使用GPS时间作为同步时间。

延时测量

gPTP定义了两类报文用于时间同步,事件型报文和一般型报文。在PTP节点入口和出口打上时间戳的报文是事件型报文,没有打时间戳需求的是一般型报文。

  • 事件型报文:Sync、Pdelay_Req、Pdelay_Resp
  • 一般型报文:Follow_Up、Pdelay_Resp_Follow_Up

图片来源:IEEE 802.1AS 2020
传播延时测量方法为两步对等路径延时/对等延时,测量的方向为initiator向responder发起,通过Pdelay_Req、Pdelay_Resp和Pdelay_Resp_Follow_Up获取四个时间t1,t2,t3和t4,测量步骤和计算方法如下:

  • 请求方发送Pdelay_Req报文,记录出口时间戳t1
  • 应答方收到该报文,记录入口时间戳t2;此时请求方获取的时间是t1
  • 应答方反馈Pdelay_Resp报文,记录出口时间戳t3,并在报文中携带t2
  • 请求方收到该报文,记录入口时间戳t4;此时请求方获取的时间是t1,t2,t4
  • 应答方再次发送Pdelay_Resp_Follow_Up报文,并在报文中携带t3;此时请求方获取到时间t1,t2,t3和t4
  • 根据两个方向的时间差值计算传播延时

在这里插入图片描述
需要注意的是,这种测量方式不考虑链路方向的延时差异,假定请求方和应答方之间两个方向的报文传播时间是对称的;这种计算方法对应请求方和应答方走时一致的理想情况,而实际二者的频率差是必然存在的。当请求方的时钟频率比应答方的慢,D会比实际值小。感兴趣的读者可以自己计算一下。

转发延时的测量基于本地时钟,计算报文的出口时间戳和入口时间戳差值。

802.1AS并未规定传播延时测量的方向,但是在车载网络中,一般由Slave端向Master端发起。

由于时间频率不同会导致校准误差,我们需要得到相邻节点的时间频率rateRatio,并将其计入传播延时中。

计算方法为统计连续的Pdelay_Resp和Pdelay_Resp_Follow_Up报文时间戳信息。如下图所示,第一次发送Pdelay_Resp的时间为t3,到达另一端的时间为t4,第二次发送Pdelay_Resp的时间为t3’,到达时间为t4’。

在这里插入图片描述
频率比值计算结果为:

在这里插入图片描述
计入频率比值的传播延时为:

在这里插入图片描述
相邻节点之间的频率比被称为neighborRateRatio,节点与主时钟之间频率比被称为rateRatio;rateRatio是neighborRateRatio的累积乘积,而由于neighborRateRatio与1非常接近(以ppm为单位),实际计算中也可通过累计相加的方式得到。

在这里插入图片描述
传播延时一般是ns-μs量级,转发延时由于交换机转发与处理能力的限制,一般是μs-ms量级。因此,时间同步的误差来源主要是转发延时。

▎实现方式-PTP报文

延时测量方法,测量结果,PTP端口信息和发送周期在时间同步报文(PTP报文)中携带。PTP报文位于MAC帧的数据段,目的MAC地址为固定组播地址01-80-C2-00-00-0E,以太网帧类型为固定0x88F7。

在这里插入图片描述
PTP报头为34字节,包含报文类型messageType,PTP版本号versionPTP,PTP报文字节数messageLength等内容。

Correction field字段是上游节点相对于GM节点的修正值,换算成ns时间需要除以2^16。当follow_up报文中的originTimestamp加上该字段以后,就是上游节点发送该Sync报文的同步时间。

在这里插入图片描述

Sync报文

Sync报文根据一步法和两步法的不同,报文格式存在差异。一步法仅由Sync报文携带延时和频率比值信息。

图片来源:IEEE 802.1AS 2020
如果报头中的两步法标志位为True,那么Sync报文格式如IEEE 802.1AS 2020中的表11-8所示;如果标志位为False,那么Sync报文格式如IEEE 802.1AS 2020中的表11-9所示。由于一步法不发送Follow_Up报文,因此GM节点发送Sync报文的时间originTimestamp和TLV字段统一在Sync报文中携带。车载应用中,通常使用两步法。

在这里插入图片描述

Follow Up报文

Follow_Up报文携带相关Sync报文的出口时间戳信息。

preciseOriginTimestamp是GM节点发送Sync报文的时间。

在这里插入图片描述

Pdelay_Req报文

报文的数据段不携带信息,为保留值。
在这里插入图片描述

Pdelay_Resp报文

requestReceiptTimestamp为Responder接收Pdelay_Req报文的入口时间。

requestingPortIdentity为Pdelay_Req报文的源端口信息。

在这里插入图片描述

Pdelay_Resp_Follow_Up报文

responseOriginTimestamp为Responder发送Pdelay_Resp报文的出口时间。

requestingPortIdentity同样为Pdelay_Req报文的源端口信息。

在这里插入图片描述

▎总结

TSN任务组颁布了IEEE 802.1AS-2020协议以解决本地局域网中各组件的时间同步问题。在一个gPTP域中,各节点测量传播延时,转发延时和频率比值。通过BMCA算法或预配置方式,系统确定主时钟节点并向其他节点发送时间同步报文,完成时间同步。本期协议解读到此就告一段落了,下期我们将为大家带来更多精彩的TSN协议系列解读,敬请期待。

▎参考文献

[1] IEEE Std 802.1AS™‐2020 IEEE Standard for Local and Metropolitan Area Networks —Timing and Synchronization for Time‐Sensitive Applications

[2] IEEE Std 1588™-2008 IEEE Standard for a Precision Clock Synchronization Protocol for Networked Measurement and Control Systems

这篇关于TSN协议原理!看完这一篇就够了(1)——时钟同步IEEE802.1AS-2020的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

kotlin中的模块化结构组件及工作原理

《kotlin中的模块化结构组件及工作原理》本文介绍了Kotlin中模块化结构组件,包括ViewModel、LiveData、Room和Navigation的工作原理和基础使用,本文通过实例代码给大家... 目录ViewModel 工作原理LiveData 工作原理Room 工作原理Navigation 工

Java的volatile和sychronized底层实现原理解析

《Java的volatile和sychronized底层实现原理解析》文章详细介绍了Java中的synchronized和volatile关键字的底层实现原理,包括字节码层面、JVM层面的实现细节,以... 目录1. 概览2. Synchronized2.1 字节码层面2.2 JVM层面2.2.1 ente

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

MySQL的隐式锁(Implicit Lock)原理实现

《MySQL的隐式锁(ImplicitLock)原理实现》MySQL的InnoDB存储引擎中隐式锁是一种自动管理的锁,用于保证事务在行级别操作时的数据一致性和安全性,本文主要介绍了MySQL的隐式锁... 目录1. 背景:什么是隐式锁?2. 隐式锁的工作原理3. 隐式锁的类型4. 隐式锁的实现与源代码分析4

MySQL中Next-Key Lock底层原理实现

《MySQL中Next-KeyLock底层原理实现》Next-KeyLock是MySQLInnoDB存储引擎中的一种锁机制,结合记录锁和间隙锁,用于高效并发控制并避免幻读,本文主要介绍了MySQL中... 目录一、Next-Key Lock 的定义与作用二、底层原理三、源代码解析四、总结Next-Key L