当前位置: 首页 > news >正文

在QNX中运行PTPD实现gPTP同步问题的排查与解决

文章目录

    • 0. 引言
    • 1. 问题定位
      • 1.1 初步排查
      • 1.2 Wireshark抓包验证
      • 1.3 Linux环境对比
    • 2. 问题分析与解决
      • 2.1 可能原因
      • 2.2 混杂模式测试
    • 3 结论

0. 引言

PTPD是一种时间同步的开源实现,遵循IEEE1588 协议,是通过在主从时钟之间传输同步报文来实现同步,主要分为两个阶段:偏差测量和延迟测量,同步过程重要的报文如下图所示:

在QNX系统中运行PTPD时,遇到了无法进行gPTP(通用精确时间协议)同步的问题。经过排查,发现是QNX开发板无法收到数据链路层的PTPv2数据包引起的问题。

更多阅读请查看 PTPD 在 QNX 系统上的授时精度验证与误差排查
以下是问题排查过程及解决方法的详细记录。

1. 问题定位

1.1 初步排查

首先,尝试在报文接收的位置打日志,发现没有报文过来。一路追踪至select函数没有触发。

ret=select(nfds,readfds,0,0,tv_ptr);

随后,尝试不用gPTP的event和general的socket,而是用原始套接字(raw socket)来接收数据,但依然无法收到报文。

1.2 Wireshark抓包验证

为进一步确认问题,尝试在QNX开发板中未启动PTPD进程的情况下,使用以下指令进行抓包:

./tcpdump-c100-w./tmp.pcap

在不同的主时钟启动方式下,抓包结果如下:

  • 主时钟以gPTP方式启动:pcap文件中没有授时报文。

  • 主时钟以PTP的UDP方式启动:pcap文件中有授时报文。

  • 主时钟以PTP的L2方式(用数据链路层传输数据)启动:pcap文件中没有授时报文。

1.3 Linux环境对比

为了验证问题是否特定于QNX开发板,我在Linux开发板中进行了相同的测试,主时钟发gPTP报文,然后使用以下指令抓包:

./tcpdump-c100-w./tmp.pcap

在Linux开发板中,可以抓到数据链路层的报文。由此可以判断,问题与QNX开发板中的PTPd无关,很可能是QNX开发板本身无法收到数据链路层的包。

2. 问题分析与解决

2.1 可能原因

分析认为数据链路层的报文是有到达QNX开发板的,但在底层没有被正确处理。可能的原因是驱动没有适配,最有可能的是网卡驱动没有开启混杂模式。

一般情况下,网卡往往只会接收目的MAC地址是它的数据包而不会接收目的MAC地址不是它的数据包。

混杂模式就是指网卡能接受所有通过它的数据流,无论是什么模式、什么地址的。当网卡处于这种“混杂”模式时,它对所有遇到的每一个数据帧都产生一个硬件中断,以提醒操作系统处理流经该物理媒体上的每一个报文包。
这样wireshark或者tcpdump就可以在数据链路层的报文看到gPTP的报文。

2.2 混杂模式测试

后来确认开启混杂模式时,能够收到gPTP数据链路层报文。具体操作如下:

  1. 用以下指令查看结果:

    io320x00ff0c0004
  2. 从右往左,从0开始,第4位,将其置为1,然后重新设置进去,使用以下指令:

    io320x00ff0c0004 0x02B2045A

]

经过以上设置,可以看到QNX开发板和主时钟的gPTP报文交互正常。

3 结论

在QNX系统中运行PTPD进行gPTP同步时,若无法收到数据链路层的报文,建议开启混杂模式,并确认底层驱动的适配情况。

http://www.jsqmd.com/news/729628/

相关文章:

  • 安全带 安全绳 检测数据集】 数据集共有2000张;
  • 语音转文本与机器翻译系统中合成数据的可靠性研究
  • 2026崇州物流托盘技术解析:崇州环保托盘生产厂家/崇州设备木箱包装/崇州货运托盘/崇州重型托盘/崇州重型木箱包装/选择指南 - 优质品牌商家
  • 为什么 LinkedBlockingQueue 并发性能这么强?一文吃透双锁机制
  • project_travel_advisor:如何使用Google地图和React构建终极旅行助手应用
  • 保姆级教程:在RTX 3090上从零部署MIT-BEVFusion(附CUDA-BEVFusion完整配置流程)
  • 时间序列模型选型指南:AR、MA、ARMA、ARIMA到底该用哪个?看完这篇不再纠结
  • WSL2里的Arch太久没更新?一招解决pacman签名错误,告别invalid or corrupted package
  • linux下手工安装ollama0.9.6
  • 开源免费的WPS AI 软件 察元AI文档助手:链路 020:runPlainDocumentAssistantExecution 单次 chatCompletion
  • ARM原子操作指令解析:LDSETP与LDSMAX实战指南
  • 保姆级教程:在Ubuntu 20.04上从零部署PointPillars ROS节点(含CUDA 11.7/Spconv 2.x避坑指南)
  • 别再为覆盖率头疼了!聊聊Test Point如何帮你搞定ATPG Pattern数量
  • 终极Fabric物品与方块API开发指南:从零开始创建自定义游戏元素的完整流程
  • 如何选择最佳Mac应用清理工具:Pearcleaner 2025年完整使用指南
  • Fuel Core 终极商业模式解析:区块链基础设施的可持续盈利探索
  • Ollamac本地AI对话伴侣:隐私优先的图形化大模型客户端部署与实战
  • React-Cropper深度解析:从基础配置到高级用法
  • 语言模型序列推理:从理论到实践的范式转变
  • 中兴STB调试工具|永久版|免沙箱直运行|可复制文件
  • 你所不知道的关于AI的27个冷知识——AI与环境保护
  • 别再搜XML了!IDEA 2024.1新版本里,Spring Boot启动报‘命令行太长’的3秒修复法
  • 大模型赋能邻域搜索:G-LNS优化算法解析
  • 超导量子处理器ECR门误差分析与抑制技术
  • 你所不知道的关于AI的27个冷知识——AI的计算能力与能源消耗
  • Gopeed微前端架构解析:10个模块化开发与按需加载的终极技巧
  • 告别老InputSystem!UE5.3增强输入系统实战:从蓝图到C++完整配置流程
  • 如何用ChatTTS Top-K采样提升语音生成质量:简单实用的优化指南
  • Vibe Space技术:实现概念级图像混合的突破
  • 语义学是否存在普遍真理?从理论分野到NLP的破局可能