CN106230540B - 高精度ntp报文接收方法和发送方法 - Google Patents
高精度ntp报文接收方法和发送方法 Download PDFInfo
- Publication number
- CN106230540B CN106230540B CN201610622222.6A CN201610622222A CN106230540B CN 106230540 B CN106230540 B CN 106230540B CN 201610622222 A CN201610622222 A CN 201610622222A CN 106230540 B CN106230540 B CN 106230540B
- Authority
- CN
- China
- Prior art keywords
- message
- ntp
- ntp message
- time
- fpga
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04J—MULTIPLEX COMMUNICATION
- H04J3/00—Time-division multiplex systems
- H04J3/02—Details
- H04J3/06—Synchronising arrangements
- H04J3/0635—Clock or time synchronisation in a network
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04J—MULTIPLEX COMMUNICATION
- H04J3/00—Time-division multiplex systems
- H04J3/02—Details
- H04J3/06—Synchronising arrangements
- H04J3/0635—Clock or time synchronisation in a network
- H04J3/0685—Clock or time synchronisation in a node; Intranode synchronisation
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer And Data Communications (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
高精度NTP报文接收方法,涉及通信技术。本发明包括下述步骤:1)PHY接口接收报文,FPGA从PHY发到MAC接口的报文中识别出NTP报文,并提取出NTP报文的源IP地址和IP标识数据;2)FPGA记录NTP报文的接收时间戳,并将NTP报文的源IP地址和IP标识数据作为一条数据缓存到存储区;3)CPU处理MAC接收报文,对于其中的NTP报文,根据NTP报文的源IP地址和IP标识从存储区读取出NTP报文的接收时间时间戳。本发明提高了NTP报文/接收发送时间戳的准确性。
Description
技术领域
本发明涉及通信技术。
背景技术
随着科技的持续发展,许多行业对时间同步的要求越来越高,高精度的、可靠的系统时间同步是诸多领域安全可靠运行的保障,如通信、电力、交通、金融证券、航天科研等。
在传统的时间同步技术中,主要由客户端与服务器间直接通过携带时间戳的报文进行交换,并利用一定的算法来进行时间同步。随着目前网络对安全性要求的不断提高,为了防止恶意修改或复制时间戳造成安全风险,基于认证的网络时间同步技术得到广泛地应用。
NTP是一种广泛应用在网络成员之间的时间同步协议,实现NTP协议的网络成员间通过交互NTP报文使得彼此的时钟一致,从而实现自动调节各个系统时钟的功能。NTP不仅可提供精准的时间同步服务,而且支持认证机制和MD5验证。因此,NTP是一种具有抗网络安全风险的网络时间同步协议。
传统的NTP主要由CPU采用软件的方式来获取NTP报文的收发时间戳,因此NTP的授时精度一般都在毫秒级别,采用专用的服务器也只能达到微秒级。因此,NTP收发时间戳的精度是影响NTP时间同步精度的最主要因素,NTP报文的收发时间戳的精度越高,NTP时间同步的精度才能提高。
中国专利CN201210008137.2“高精度NTP授时系统的授时方法”公开了一种利用可编程逻辑器件对经过的NTP报文进行时间戳插入修改并修改CRC32校验来保证报文完整性,来提高NTP的授时校时精度。该方法NTP报文的生成或处理都有CPU来完成,只是在MAC和PHY之间,利用可编程逻辑器件对经过的NTP报文进行时间戳插入或修改,并重新计算替换报文的CRC32校验。这种处理方法不能适用于带有认证机制的NTP报文。因为带有认证机制的NTP报文自报文生成后,若报文的信息传输过程中被修改,会破坏NTP报文认证信息的完整性,接收端将丢弃不能通过认证的NTP报文。
发明内容
本发明所要解决的技术问题是,提供一种能够准确获取NTP报文的接收时间的NTP报文接收方法,以及一种能够准确控制NTP报文的发送时间的NTP报文发送方法。
本发明解决所述技术问题采用的技术方案是,高精度NTP报文接收方法,其特征在于,包括下述步骤:
1)PHY接口接收报文,FPGA从PHY发到MAC接口的报文中识别出NTP报文,并提取出NTP报文的源IP地址和IP标识数据;;
2)FPGA记录NTP报文的接收时间戳,并将NTP报文的源IP地址和IP标识数据作为一条数据缓存到存储区(FIFO);
3)CPU处理MAC接收报文,对于其中的NTP报文,根据NTP报文的源IP地址和IP标识从FIFO读取出NTP报文的接收时间时间戳。
进一步的,所述步骤3)中,CPU依据NTP报文的源IP地址和IP标识数据在FIFO中进行查找配对,确定NTP报文的接收时间戳。(从FIFO中依次读取一条数据根据源IP地址和IP标识数据与接收的NTP报文的源IP地址和IP标识进行比较,当比较结果相同时,将该条数据的时间数据作为接收NTP报文的接收时间数据。)
本发明还提供一种高精度NTP报文发送方法,其特征在于,包括下述步骤:
a)CPU生成NTP报文并由MAC发到FPGA,其发送时间戳中包含了预留时延,所述预留时延为报文从生成到发送端口预计所需的发送时间;
b)FPGA对来自MAC发送接口的报文进行识别和缓存,识别出其中的NTP报文,并记录NTP报文的发送时间戳数据;
c)FPGA优先安排NTP报文在其发送时间戳时刻将NTP报文发送到PHY接口。
进一步的,步骤c)中,FPGA依据NTP报文的发送时间戳和当前系统时间,计算下一帧可发的非NTP报文(非NTP报文可能缓存了很多帧,应该是先查看下一帧,如果下一帧满足发送条件,则发该帧;完成了,又重复该过程)的长度,如果可发的非NTP报文长度大于缓存的非NTP报文长度,则将该非NTP报文发送至PHY接口;如果可发的非NTP报文长度小于或等于缓存的非NTP报文长度,则等待至NTP报文发送时间戳的时刻,在发送时间戳的时刻将NTP报文发到PHY接口。
步骤b)中,FPGA将NTP报文存储在NTP报文存储区,将非NTP报文存储在非NTP报文存储区。对于非NTP报文缓存,应该记录报文长度,便于发送调度计算;对NTP报文,应该从报文中提取出发送时间戳数据,作为该报文的发送时间控制数据。
本发明通过硬件方式获取NTP报文的接收时间戳,提高了NTP报文接收时间戳精度;通过NTP报文的特征数据与接收时间戳来匹配,保证NTP接收时间与报文处理时的数据一致性。这样从获取时间戳的方式及数据的可靠匹配保证了NTP报文的接收时间戳的精度。
本发明通过硬件方式控制NTP报文的发送时间与报文中所设置的时间数据一致,提高了NTP报文发送时间戳的准确性。
本发明不改变报文的任何内容,保证了报文的完整性,适用于带有认证及MD5验证功能的NTP应用需求。
附图说明
图1为本发明的方案示意图。
具体实施方式
参见图1。
在NTP报文接收端,从PHY发到与MAC接口的以太报文进行报文识别,根据NTP报文的特征如UDP的端口号123识别出是否是NTP报文,对于NTP报文提出NTP报文源IP地址及IP标识数据,并记录从PHY接口接收报文时刻的时间戳,再将时间戳数据、源IP地址及IP标识数据作为一条数据缓存到FIFO中;CPUFIFO的读取接口获取该NTP报文的接收时间戳数据并可以根据源IP地址及IP标识数据来准确实现接收时间戳与NTP报文的匹配,该报文经过报文识别后直接送到MAC接收接口;对于非NTP报文,直接送到MAC接收接口。以上皆由FPGA完成。
CPU从MAC中解析出NTP报文并从FIFO接口获取报文的接收时间戳,即得到NTP报文到达接收端的准确的时间戳数据。对于时间戳与报文的通道不一致,采用提取报文中的特征数据与时间戳来进行匹配,从而保证来时间戳数据的可靠性和可操作性。
在NTP报文发送端,当CPU生成NTP报文时,对于NTP报文中的发送时间戳数据要充分考虑报文从生产到发送端口发出的时间,因此发送时间戳数据要落后于NTP报文的实际生成时间。从MAC发送接口发出的以太报文,交FPGA,经过报文识别,根据NTP报文的特征如UDP的端口号123识别出是否是NTP报文,并提取出NTP报文中的发送时间戳数据,并将识别出的报文分类缓存,将NTP报文及其发送时间戳数据缓存于NTP报文缓存区域,将非NTP报文及其长度缓存于非NTP报文缓存区域。根据缓存区域中的NTP报文及非NTP报文缓存情况进行发送调度控制,优先保证NTP报文在其数据报文中设置的发送时间戳时刻发送,在无NTP报文发送或NTP报文的等待时间长时发送非NTP报文缓存区的以太报文数据。发送调度可以根据NTP报文的发送时间戳及当前系统时间,计算出可发非NTP报文的报文长度,如果该长度大于非NTP报文缓存区域中的报文长度,则将该报文从非NTP报文缓存区域发出到PHY接口;若计算出的长度小于非NTP报文缓存区域的报文长度,则等待NTP报文的发送,当NTP报文的发送时刻到来时,立即将NTP报文发送到PHY接口。
NTP时间在FPGA内根据工作时钟的控制自动运行时间,CPU根据参考时间或NTP报文计算出系统的时间偏差,通过校时接口校准系统NTP时间。这种通过时钟在FPGA内运行时间的方式,从硬件上保证了时间运行的准确性,并且便于FPGA实时获取NTP时间数据。
实施例:
一种高精度的NTP实现方案如图1,主要由PHY、FPGA、MAC和CPU构成,其中PHY与MAC完成以太报文的收发功能;CPU解析及产生以太报文,并计算系统时间的偏差,完成系统时间维护等功能;FPGA主要实现NTP时间,NTP报文的接收时间戳记录及NTP报文的发送时间控制等功能来保证NTP的收发时间戳的精度。NTP报文结构如表1。NTP在客户端/服务器模式下实现时间同步过程主要有:首先客户端向服务器发送NTP同步请求报文,报文离开客户端的时间T1,对应NTP报文中的数据Originate Timestamp;当服务器接收到该报文时,需要记录报文到达时刻的时间T2,对应NTP报文中的数据Receive Timestamp,同时服务器向客户端回复响应报文,其中响应报文的携带其发送时间戳T3,对于NTP报文中的数据TransmitTimestamp;客户端接收到响应报文的同时得到相应报文到达时间戳T4。这样NTP客户端与服务器端完成1次NTP报文交互过程中就获得了4个时间戳数据,通过计算就能得到客户端与服务器的路径延迟和客户端与服务器的时间偏差。
对于客户端,当CPU生成NTP请求报文时,首先计算MAC中未发出数据的数量,预先估计NTP请求报文从生成到发出的所需时间,然后将当前时间加上预估时间作为NTP请求报文的Originate Timestamp数据。从MAC发送接口发出的以太报文,经过报文识别,识别出NTP请求报文并从报文中提取出发送时间戳数据T1,然后将NTP请求报文及T1缓存在设置的NTP报文缓存区域;对于识别出的非NTP请求报文,将报文及报文长度缓存在设置的非NTP报文缓存区域。发送调度实时查询NTP报文及非NTP报文缓存区域的报文缓存情况,若有NTP报文缓存,查询NTP报文的发送时间T1,计算出T1与当前时间可发送报文的长度,若可发报文长度小于下1帧非NTP报文的长度,则不发送任何报文,等待直到系统时间等于T1时,立即将NTP报文发到PHY接口;若可发报文的长度大于或等于下1帧非NTP报文的长度,则发送非NTP报文。每完成1帧以太报文的发送,重复前面的判断过程。若无NTP报文缓存,则直接将非NTP报文缓存区域缓存的报文发到PHY接口。
对于服务器端,对PHY发到MAC的以太报文经过报文识别,识别出NTP请求报文时记录当前的系统时间作为NTP的接收时间戳T2,并提取出NTP请求报文的源IP地址及IP标识数据,最后将T2、源IP地址及IP标识数据写入FIFO中。CPU接收解析NTP请求报文,并从FIFO读取接口获取T2、源IP地址及IP标识数据,根据原IP地址及IP标识数据与解析的NTP报文的源IP地址及IP标识进行比对,确定于该NTP报文相对应的T2数据。
对于服务器端,当接收NTP请求报文后需要向客户端发出NTP响应报文。当CPU生成NTP响应报文时,首先计算MAC中未发出数据的数量,预先估计NTP响应报文从生成到发出的所需时间,然后将当前时间加上预估时间作为NTP响应报文的Transmit Timestamp数据。从MAC发送接口发出的以太报文,经过报文识别,识别出NTP响应报文并从报文中提取出发送时间戳数据T3,然后将NTP响应报文及T3缓存在设置的NTP报文缓存区域;对于识别出的非NTP请求报文,将报文及报文长度缓存在设置的非NTP报文缓存区域。发送调度实时查询NTP报文及非NTP报文缓存区域的报文缓存情况,若有NTP报文缓存,查询NTP报文的发送时间T3,计算出T3与当前时间可发送报文的长度,若可发报文长度小于下1帧非NTP报文的长度,则不发送任何报文,等待直到系统时间等于T3时,立即将NTP报文发到PHY接口;若可发报文的长度大于或等于下1帧非NTP报文的长度,则发送非NTP报文。每完成1帧以太报文的发送,重复前面的判断过程。若无NTP报文缓存,则直接将非NTP报文缓存区域缓存的报文发到PHY接口。
对于客户端,对PHY发到MAC的以太报文经过报文识别,识别出NTP响应报文时记录当前的系统时间作为NTP的接收时间戳T4,并提取出NTP响应报文的源IP地址及IP标识数据,最后将T4、源IP地址及IP标识数据写入FIFO中。CPU接收解析NTP响应报文,并从FIFO读取接口获取T4、源IP地址及IP标识数据,根据原IP地址及IP标识数据与解析的NTP报文的源IP地址及IP标识进行比对,确定于该NTP报文相对应的T4数据。
表1。
Claims (4)
1.高精度NTP报文接收方法,其特征在于,包括下述步骤:
1)PHY接口接收报文,FPGA从PHY发到MAC接口的报文中识别出NTP报文,并提取出NTP报文的源IP地址和IP标识数据;
2)FPGA记录NTP报文的接收时间戳,并将NTP报文的源IP地址和IP标识数据作为一条数据缓存到存储区;
3)CPU处理MAC接收报文,对于其中的NTP报文,根据NTP报文的源IP地址和IP标识在FIFO中进行查找配对,确定NTP报文的接收时间戳。
2.高精度NTP报文发送方法,其特征在于,包括下述步骤:
a)CPU生成NTP报文并由MAC发到FPGA,其发送时间戳中包含了预留时延,所述预留时延为报文从生成到发送端口预计所需的发送时间;
b)FPGA对来自MAC发送接口的报文进行识别和缓存,识别出其中的NTP报文,并记录NTP报文的发送时间戳数据;
c)FPGA优先安排NTP报文在其发送时间戳时刻将NTP报文发送到PHY接口。
3.如权利要求2所述的高精度NTP报文发送方法,其特征在于,所述步骤c)为:
FPGA依据NTP报文的发送时间戳和当前系统时间,计算下一帧可发的非NTP报文的长度,如果可发的非NTP报文长度大于缓存的非NTP报文长度,则将该非NTP报文发送至PHY接口;如果可发的非NTP报文长度小于或等于缓存的非NTP报文长度,则等待至NTP报文发送时间戳的时刻,在发送时间戳的时刻将NTP报文发到PHY接口。
4.如权利要求2所述的高精度NTP报文发送方法,其特征在于,步骤b)中,FPGA将NTP报文存储在NTP报文存储区,将非NTP报文存储在非NTP报文存储区。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610514360 | 2016-06-30 | ||
CN2016105143602 | 2016-06-30 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN106230540A CN106230540A (zh) | 2016-12-14 |
CN106230540B true CN106230540B (zh) | 2019-03-26 |
Family
ID=57536461
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610622222.6A Active CN106230540B (zh) | 2016-06-30 | 2016-08-01 | 高精度ntp报文接收方法和发送方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN106230540B (zh) |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108599887A (zh) * | 2018-04-24 | 2018-09-28 | 新华三技术有限公司 | 一种时差计算方法和转发设备 |
CN108737006A (zh) * | 2018-05-30 | 2018-11-02 | 南京南瑞继保电气有限公司 | 一种时间同步方法、客户端及计算机可读存储介质 |
CN109462453A (zh) * | 2018-11-22 | 2019-03-12 | 电信科学技术第五研究所有限公司 | 一种基于光纤网络的高精度时间同步方法 |
CN111385049B (zh) * | 2018-12-29 | 2022-09-27 | 中兴通讯股份有限公司 | 一种时间校正方法、装置、系统及存储介质 |
CN109379160A (zh) * | 2018-12-30 | 2019-02-22 | 广东大普通信技术有限公司 | 一种时钟校准服务器及方法 |
CN113746746A (zh) * | 2020-05-30 | 2021-12-03 | 华为技术有限公司 | 数据处理方法及设备 |
CN111682920B (zh) * | 2020-07-23 | 2022-04-12 | 中国电子科技集团公司第五十四研究所 | 一种用于ntp授时的协议转换装置 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN202617148U (zh) * | 2012-06-06 | 2012-12-19 | 北京北变智达科技有限公司 | 网络数据接收时间的记录装置 |
CN103095607A (zh) * | 2013-02-21 | 2013-05-08 | 南京磐能电力科技股份有限公司 | 一种实时优先级以太网控制器实现方法 |
CN104113517A (zh) * | 2013-04-22 | 2014-10-22 | 华为技术有限公司 | 时间戳生成方法、装置及系统 |
CN104170291A (zh) * | 2012-02-22 | 2014-11-26 | 瑞典爱立信有限公司 | 用于处理精确时间协议的方法和网络节点 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
AU2007253824A1 (en) * | 2006-05-19 | 2007-11-29 | Symmetricom, Inc. | Network time protocol precision timestamping service |
CN101599894B (zh) * | 2008-06-04 | 2013-01-30 | 华为技术有限公司 | 具有时钟信息报文的处理方法、装置及系统 |
CN101662702B (zh) * | 2008-08-27 | 2013-06-26 | 华为技术有限公司 | 无源光网络中的时延控制方法、光线路终端和无源光网络 |
CN102983959B (zh) * | 2011-09-05 | 2015-05-13 | 盛科网络(苏州)有限公司 | 在多个mac中实现ptp一步模式和两步模式的方法及装置 |
-
2016
- 2016-08-01 CN CN201610622222.6A patent/CN106230540B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104170291A (zh) * | 2012-02-22 | 2014-11-26 | 瑞典爱立信有限公司 | 用于处理精确时间协议的方法和网络节点 |
CN202617148U (zh) * | 2012-06-06 | 2012-12-19 | 北京北变智达科技有限公司 | 网络数据接收时间的记录装置 |
CN103095607A (zh) * | 2013-02-21 | 2013-05-08 | 南京磐能电力科技股份有限公司 | 一种实时优先级以太网控制器实现方法 |
CN104113517A (zh) * | 2013-04-22 | 2014-10-22 | 华为技术有限公司 | 时间戳生成方法、装置及系统 |
Also Published As
Publication number | Publication date |
---|---|
CN106230540A (zh) | 2016-12-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106230540B (zh) | 高精度ntp报文接收方法和发送方法 | |
US10158444B1 (en) | Event-driven precision time transfer | |
CN106209948B (zh) | 一种数据推送方法及装置 | |
Hedayat et al. | A two-way active measurement protocol (twamp) | |
CN102739659B (zh) | 一种防重放攻击的认证方法 | |
US9042411B1 (en) | System and method for accurate time sampling in presence of output delay | |
US9009336B2 (en) | Method and system for pacing, acking, timing, and handicapping (path) for simultaneous receipt of documents | |
US8824687B2 (en) | Method and system for pacing, acking, timing, and handicapping (path) for simultaneous receipt of documents employing encryption | |
WO2012166711A1 (en) | Method for improving accuracy in computation of one-way transfer time for network time synchronization | |
US8995669B1 (en) | Updating shared keys | |
EP3447631B1 (en) | Writing trajectory synchronization method and system for multiple clients | |
CN103580846B (zh) | 一种跨非1588网络传输精密时钟报文的方法及系统 | |
WO2015184890A1 (zh) | 一种丢包的测量方法及装置 | |
CN101459502A (zh) | 一种网络时钟同步的方法与装置 | |
CN103124263A (zh) | 一种广告推送系统及广告推送设备、广告服务器 | |
EP2293524A1 (en) | Set-up of media stream transmission and server and client for media stream transmission | |
WO2018107606A1 (zh) | 物联网中消息传递方法和装置 | |
CN103401946A (zh) | Http上传加速方法和系统 | |
US6658004B1 (en) | Use of beacon message in a network for classifying and discarding messages | |
CN109978479A (zh) | 一种电子发票报销方法、装置、数据共享服务器及系统 | |
WO2018227703A1 (zh) | 物联网中消息传递方法和装置 | |
CN114221969A (zh) | 基于近场通信的数据同步方法、终端、服务端、系统 | |
CN109714438A (zh) | 一种地铁综合监控系统实时数据跨网摆渡装置及方法 | |
CN106788842A (zh) | 一种ptp报文的处理方法及soc | |
CN109607341A (zh) | 基于区块链的电梯运转信息管理系统 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
CB02 | Change of applicant information | ||
CB02 | Change of applicant information |
Address after: 610031 Sichuan city of Chengdu province Jinjiang District Dacisi Road No. 22 Applicant after: Telecommunication science and technology fifth Research Institute Co., Ltd. Address before: 610000 Sichuan city of Chengdu province shudutaidao Daci Temple Road, No. 22 Applicant before: Information Industry Department No. 5 Telecommunication Technologics Research Institute |
|
GR01 | Patent grant | ||
GR01 | Patent grant |