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

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

3天内不再提示

英创信息技术IEEE1588协议驱动分布式系统高精度同步触发简介

英创信息技术 来源:英创信息技术 作者:英创信息技术 2020-02-12 10:35 次阅读

IEEE1588是精确网络对时协议,简称PTP。它通过硬件实现的时间标签(hardware time stamp),使对时精度达到亚微秒级(< 1us),大大高于常规的网络对时协议(NTP)。PTP协议的另一个特色是它可输出精确时间同步的硬件脉冲,通常称为PPS脉冲。在网络化的嵌入式系统中,利用PTP的硬件PPS脉冲,可对处于不同位置的多台设备实现同步触发的功能。这对分布式系统的数据采集、实时控制都具有非常的意义。

英创公司的多款嵌入式主板,ESM7000、ESM6802和ESM6800,其网络接口均支持PTP协议,且可输出PPS脉冲,因此是分布式智能设备的理想嵌入式平台。以下将以ESM7000为例,介绍实现分布式同步触发的软硬件方案。

基于PTP的同步触发软件流程

ESM7000预装的Linux平台文件系统中,已包含了PTP对时及硬件时间同步的完整工具,即ptp4l和phc2sys,同时可方便的控制PPS脉冲的使能。在这个基础上,按照图1所示流程就可实现同步触发的功能。

图1同步触发软件流程

在实际的测试中发现,PTP的对时精度与网络环境有密切关系。在单一的100M网络环境所获得的设备间的同步精度在±200ns;而在1000M网环境,同步精度就下降到±1us;混合网络环境,同步精度可差至±15us。

同步触发脉冲的硬件方案

所谓硬件方案,是指图1中触发脉冲生成器的实现方案。以PTP协议生成的周期性PPS脉冲为基础,由应用程序生成触发使能信号,再通过一个简单的D触发器生成最后的触发脉冲。硬件方案涉及3个信号如下:

●PPS_OUT:整秒脉冲输出,即周期固定为1秒,在ESM7000上,PPS的脉冲宽度为10ns,上升沿有效。

●TRG_EN:触发使能,通常用一位GPIO来实现,其高电平有效。

●TRG_PULSE:触发脉冲,上升沿有效;在TRG_EN为低时,将强制TRG_PULSE为低;当TRG_EN为高时,后续的PPS_OUT脉冲上升沿将锁存高电平,从而是TRG_PULSE变高电平。TRG_PULSE脉冲上升沿将将作为系统采集控制硬件单元的触发输入,触发各个嵌入式设备同步动作。

图2同步触发脉冲生成电路原理

在图2中,TRG_PULSE还可反馈给ESM7000主板,通知同步触发已发生。但不是必须的。

大部分ESMARC主板均可支持PTP同步触发功能。对不同型号的主板,PPS脉冲输出管脚有所不同,如下表所示:

主板型号 PTP网口 PPS信号管脚 备注
ESM7000系列 eth0 CN2.GPIO0
ESM6802系列 eth0 CN2.GPIO24 V2.4版才支持
ESM6800系列 eth1 CN2.GPIO22 不能使用SD
ES6801 eth0 CN1.GPIO0 不能使用CAN1

对选择哪一位GPIO管脚作为TRG_EN,本方案没有限制。可根据设备的具体情况来确定。

对同步触发从设备测试

本测试用从设备的“当前时间+ 偏移量”来代替主设备发布的触发时间TRGTIME,就可用简单的脚本测试整个触发过程,具体的脚本如下:

#!/bin/sh
# trg_en_3 $1 [$2] [$3]
# $1 = 0, off ptp; = 1: on ptp
# $2 = number of seconds to delay from cuurent time
# $3 = ip:port
PATH="/usr/bin:$PATH"
E_NOARGS=85
re='^[0-9]+$'
TRG_EN_GPIO="gpio1"
TRG_EN_DIRECTORY="/sys/class/em_gpio/em_gpio/$TRG_EN_GPIO"
PHC2SYSLOG="/tmp/phc2syslog.txt"
DELAY=10
# if no arg, exit
if [ -z "$1" ]
then
echo "Usage: `basename $0` filename"
exit $E_NOARGS
fi
# if $1 != 1, off ptp and exit
if [ "$1" -ne 1 ]
then
echo 0 > /sys/class/ptp/ptp0/pps_enable
pkill phc2sys
pkill ptp4l
exit 0
fi
# get trigger delay is available, default = 10(s)
if [ $# -ge 2 ]
then
DELAY="$2"
fi
# now we start to make trg_en step by step
echo "step 1: setup gpio1 as trg_en"
if [ ! -d "$TRG_EN_DIRECTORY" ]
then
echo "config $TRG_EN_GPIO as trg_en"
echo 1 > /sys/class/em_gpio/em_gpio/export
fi
echo out > /sys/class/em_gpio/em_gpio/$TRG_EN_GPIO/direction
echo 0 > /sys/class/em_gpio/em_gpio/$TRG_EN_GPIO/value
echo "step 2: start ptp"
phc2sys -s eth0 -c CLOCK_REALTIME -w -m -u 4 > $PHC2SYSLOG &
sleep 1
ptp4l -i eth0 -s &
echo "step 3: wait phc2sys sync convergence"
num_rms=0
while [ "$num_rms" -lt 3 ]
do
RMS_ARRAY=$(cat $PHC2SYSLOG | tail -n 3 | sed -r 's/.*rms[ ]+([0-9]+).*/\1/g')
# echo "$RMS_ARRAY"
for rms in $RMS_ARRAY
do
if ! [[ $rms =~ $re ]]
then
echo "$rms is NOT an integer!"
break
fi
echo "$rms"
if [ "$rms" -lt 350 ]; then
let "num_rms += 1"
fi
done
# clear log file if rms is convergence
if [ "$num_rms" -ge 3 ]; then
echo "rms is convergence ($num_rms)"
cat /dev/null > $PHC2SYSLOG
else
let "num_rms = 0"
sleep 2
fi
done
echo "step 4: enable pps, and setup trigger time"
echo 1 > /sys/class/ptp/ptp0/pps_enable
TRGTIME=$(date +%s) # get current date in seconds
let "TRGTIME = $TRGTIME + $DELAY"
PPSTIME=$(cat /sys/class/pps/pps0/assert | cut -d '.' -f 1)
echo "TRGTIME = $TRGTIME PPSTIME = $PPSTIME"
echo "step 5: wait pps time reach trigger time"
while [ "$PPSTIME" -lt "$TRGTIME" ]
do
sleep 0.1
PPSTIME=$(cat /sys/class/pps/pps0/assert | cut -d '.' -f 1)
done
echo "step 6: now PPSTIME = TRGTIME, set trg_en"
echo 1 > /sys/class/em_gpio/em_gpio/$TRG_EN_GPIO/value
echo "step 7: wait pps time reach trigger time + 1"
let "TRGTIME = $TRGTIME + 1"
while [ "$PPSTIME" -lt "$TRGTIME" ]
do
sleep 0.1
PPSTIME=$(cat /sys/class/pps/pps0/assert | cut -d '.' -f 1)
done
echo "step 8: clear trg_en"
echo 0 > /sys/class/em_gpio/em_gpio/$TRG_EN_GPIO/value
echo "basename $0 done"

示波器可观察到,上述脚本产生的TRG_EN信号,准确使能PPS脉冲产生与之上升沿完全同步的触发脉冲TRG_PULSE。

对分布式系统同步触发功能感兴趣的客户,可通过邮件support@emtronix.com与英创公司技术部门联系,以了解详细的实现代码。

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

    关注

    87

    文章

    11225

    浏览量

    208910
  • 嵌入式主板
    +关注

    关注

    7

    文章

    6085

    浏览量

    35211
收藏 人收藏

    评论

    相关推荐

    中国唯一受邀出席2024 IEEE ISPCS企业!赛思ePRTC系统成5G时频同步网最强Buff!

    2024年10月7日-11日,国际IEEE1588精密时钟同步测量、控制和通信研讨(简称ISPCS)在日本东京成功举办。赛思受邀携面向5G时频同步网的最强Buff—ePRTC系统及相关
    的头像 发表于 10-12 11:20 333次阅读
    中国唯一受邀出席2024 <b class='flag-5'>IEEE</b> ISPCS企业!赛思ePRTC<b class='flag-5'>系统</b>成5G时频<b class='flag-5'>同步</b>网最强Buff!

    分布式故障在线监测|高精度技术选用 行波特征 故诊模型

    高精度技术选用、行波特征及故障诊断模型的相关信息: 一、分布式故障在线监测: 1、工作原理:通过在监测对象(输电线路)的不同位置分布式地安
    的头像 发表于 10-11 12:00 64次阅读

    在KeyStone器件实现IEEE1588时钟方案

    电子发烧友网站提供《在KeyStone器件实现IEEE1588时钟方案.pdf》资料免费下载
    发表于 09-26 09:10 0次下载
    在KeyStone器件实现<b class='flag-5'>IEEE1588</b>时钟方案

    TSN时钟同步 | PTP对时案例演示——基于NXP i.MX 8M Plus

    )。 IEEE1588协议简称精确时钟协议PTP(Precision Timing Protocol),它的全称是“网络测量和控制系统的精密时钟同步
    发表于 07-10 10:28

    技术分享】EtherCAT 分布式时钟简介

    分布式时钟是EtherCAT技术亮点之一,其精准同步使得整个系统都运行在统一的时钟下,每个EtherCAT从站的同步性远小于1us。本文将介
    的头像 发表于 06-04 08:25 622次阅读
    【<b class='flag-5'>技术</b>分享】EtherCAT <b class='flag-5'>分布式</b>时钟<b class='flag-5'>简介</b>

    用于IEEE 1588同步以太网的82P33814同步管理单元评估板数据手册

    电子发烧友网站提供《用于IEEE 1588同步以太网的82P33814同步管理单元评估板数据手册.rar》资料免费下载
    发表于 05-09 18:20 0次下载
    用于<b class='flag-5'>IEEE</b> <b class='flag-5'>1588</b>和<b class='flag-5'>同步</b>以太网的82P33814<b class='flag-5'>同步</b>管理单元评估板数据手册

    智慧物流中心建设:讯维分布式智慧终端技术的核心作用

    ,包括订单信息、货物信息、运输信息等。讯维分布式终端技术通过其强大的分布式计算能力,能够实时处理
    的头像 发表于 04-08 15:29 292次阅读

    智慧物流中心建设:分布式智慧终端技术的核心作用

    ,包括订单信息、货物信息、运输信息等。讯维分布式终端技术通过其强大的分布式计算能力,能够实时处理
    的头像 发表于 04-07 15:29 322次阅读

    如何实现PTP协议的精准同步时钟?

    尊敬的技术大牛们,你们好! 现有一项目需要用到贵公司的STM32F4系列产品,由于业务场景对时钟同步精度要求很高。所以需寻求你们的技术支撑,提供关于STM32F4系列的PTP
    发表于 03-26 07:57

    STM32 IEEE1588时间同步

    有谁在STM32上实现过IEEE1588精确时间同步的吗?
    发表于 02-23 16:22

    分布式大屏控制系统的屏幕同步技术

    分布式大屏控制系统的屏幕同步技术是确保系统内多个显示屏幕显示相同内容的关键技术之一。以下是实现屏
    的头像 发表于 01-29 14:40 799次阅读

    分布式大屏控制系统的工作原理

    分布式大屏控制系统是一种基于分布式计算、云计算和大数据技术的控制系统,具有高效、稳定、灵活的特点。该系统
    的头像 发表于 01-29 14:24 688次阅读

    分布式系统硬件资源池原理和接入实践

    把各个设备的硬件外设抽象为外设信息单元,外设信息在各个可信设备之间自动同步,如此,实现了外设信息的全局可见;结合分布式硬件虚拟化
    发表于 12-06 10:02

    zookeeper分布式原理

    Zookeeper是一个开源的分布式协调服务,可以用于构建高可用、高性能的分布式系统。它提供了一个简单且高效的层次命名空间,可以用来存储配置信息、状态
    的头像 发表于 12-03 16:33 618次阅读

    虹科干货 | 适用于基于FPGA的网络设备的IEEE 1588透明时钟架构

    IEEE 1588透明时钟(TC)架构,帮助您实现精确时间同步和高效通信。 在分布式系统中,传感器/执行器的事件和操作需要进行精确的时间协
    的头像 发表于 11-27 10:57 1200次阅读
    虹科干货 | 适用于基于FPGA的网络设备的<b class='flag-5'>IEEE</b> <b class='flag-5'>1588</b>透明时钟架构