【工程师分享】测试MPSoC GEM 的1588功能

FPGA开发圈 2021-05-10 00:00

作者:付汉杰,hankf@xilinx.com,文章转载自:博客园

MPSoC的MAC支持1588。在Linux Kernel的配置项中使能CONFIG_MACB_USE_HWSTAMP,并在Linux rootfs添加Linux ptp/ethtool,就可以运行1588的软件命令ptp4l。


PetaLinux下,配置Linux rootfs命令是petalinux-config -c rootfs。1588在Linux用户态的应用程序软件包是Linuxptp,可执行文件是ptp4l。




1
在zcu106之间运行1588

下面的命令,在zcu106之间运行1588。运行顺序是先在第一块单板(master)启动1588 master;再在第二块单板(slave)上启动1588 slave;接下来在第一块单板(master)终止1588 master,模拟1588 master故障;最后再在第一块单板(master)启动1588 master。


1.1. master
1588 master的命令是ptp4l -i eth0 -m。运行记录如下:

root@zcu106_vcu_trd:~# # master
root@zcu106_vcu_trd:~# uname -a
Linux zcu106_vcu_trd 5.4.0-xilinx-v2020.2 #1 SMP Wed Feb 24 10:06:51 UTC 2021 aarch64 GNU/Linux
root@zcu106_vcu_trd:~# ifconfig eth0
eth0 Link encap:Ethernet HWaddr 00:0A:35:04:D2:38
inet addr:10.164.16.102 Bcast:10.164.16.255 Mask:255.255.255.0
inet6 addr: fe80::20a:35ff:fe04:d238/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:381 errors:0 dropped:0 overruns:0 frame:0
TX packets:438 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:37123 (36.2 KiB) TX bytes:49863 (48.6 KiB)
Interrupt:31

root@zcu106_vcu_trd:~# ptp4l -i eth0 -m
ptp4l[577.050]: selected /dev/ptp0 as PTP clock
ptp4l[577.051]: port 1: INITIALIZING to LISTENING on INIT_COMPLETE
ptp4l[577.051]: port 0: INITIALIZING to LISTENING on INIT_COMPLETE
ptp4l[583.599]: port 1: LISTENING to MASTER on ANNOUNCE_RECEIPT_TIMEOUT_EXPIRES
ptp4l[583.599]: selected local clock 000a35.fffe.04d238 as best master
ptp4l[583.600]: assuming the grand master role
^C
root@zcu106_vcu_trd:~# ptp4l -i eth0 -m
ptp4l[637.574]: selected /dev/ptp0 as PTP clock
ptp4l[637.575]: port 1: INITIALIZING to LISTENING on INIT_COMPLETE
ptp4l[637.575]: port 0: INITIALIZING to LISTENING on INIT_COMPLETE
ptp4l[644.708]: port 1: LISTENING to MASTER on ANNOUNCE_RECEIPT_TIMEOUT_EXPIRES
ptp4l[644.708]: selected local clock 000a35.fffe.04d238 as best master
ptp4l[644.708]: assuming the grand master role
^Croot@zcu106_vcu_trd:~#


上面的1588 master,先启动,再停止,再启动。


1.2. slave
1588 slave的命令是ptp4l -i eth0 -s -m。运行记录如下:

root@zcu106_vcu_trd:~# # slave
root@zcu106_vcu_trd:~# uname -a
Linux zcu106_vcu_trd 5.4.0-xilinx-v2020.2 #1 SMP Wed Feb 24 10:06:51 UTC 2021 aarch64 GNU/Linux
root@zcu106_vcu_trd:~# ifconfig eth0
eth0 Link encap:Ethernet HWaddr 06:51:E5:C2:71:88
inet addr:10.164.16.8 Bcast:10.164.16.255 Mask:255.255.255.0
inet6 addr: fe80::451:e5ff:fec2:7188/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:880 errors:0 dropped:26 overruns:0 frame:0
TX packets:484 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:62884 (61.4 KiB) TX bytes:51650 (50.4 KiB)
Interrupt:31

root@zcu106_vcu_trd:~# ptp4l -i eth0 -s -m
ptp4l[577.398]: selected /dev/ptp0 as PTP clock
ptp4l[577.399]: port 1: INITIALIZING to LISTENING on INIT_COMPLETE
ptp4l[577.399]: port 0: INITIALIZING to LISTENING on INIT_COMPLETE
ptp4l[577.755]: port 1: new foreign master 000a35.fffe.04d238-1
ptp4l[581.755]: selected best master clock 000a35.fffe.04d238
ptp4l[581.755]: port 1: LISTENING to UNCALIBRATED on RS_SLAVE
ptp4l[583.754]: master offset -701 s0 freq +4079 path delay 2992
ptp4l[584.754]: master offset -957 s2 freq +3823 path delay 3037
ptp4l[584.754]: port 1: UNCALIBRATED to SLAVE on MASTER_CLOCK_SELECTED
ptp4l[585.754]: master offset -727 s2 freq +3096 path delay 3037
ptp4l[586.754]: master offset 430 s2 freq +4035 path delay 3035
ptp4l[587.754]: master offset 437 s2 freq +4171 path delay 3034
ptp4l[588.754]: master offset 351 s2 freq +4216 path delay 3035
ptp4l[589.754]: master offset 222 s2 freq +4192 path delay 3035
ptp4l[590.754]: master offset -108 s2 freq +3929 path delay 3047
ptp4l[605.754]: master offset 229 s2 freq +4239 path delay 3019
ptp4l[606.754]: master offset 18 s2 freq +4096 path delay 3035
ptp4l[607.754]: master offset -156 s2 freq +3928 path delay 3035
ptp4l[615.730]: port 1: SLAVE to LISTENING on ANNOUNCE_RECEIPT_TIMEOUT_EXPIRES
ptp4l[615.731]: selected local clock 0651e5.fffe.c27188 as best master
ptp4l[621.758]: selected local clock 0651e5.fffe.c27188 as best master
ptp4l[629.169]: selected local clock 0651e5.fffe.c27188 as best master
ptp4l[635.881]: selected local clock 0651e5.fffe.c27188 as best master
ptp4l[638.863]: selected best master clock 000a35.fffe.04d238
ptp4l[638.863]: port 1: LISTENING to UNCALIBRATED on RS_SLAVE
ptp4l[640.862]: master offset 4627 s2 freq +8664 path delay 2932
ptp4l[640.862]: port 1: UNCALIBRATED to SLAVE on MASTER_CLOCK_SELECTED
ptp4l[641.862]: master offset -22 s2 freq +5403 path delay 2978
ptp4l[642.862]: master offset -2147 s2 freq +3271 path delay 3580
ptp4l[643.862]: master offset -868 s2 freq +3906 path delay 3279
ptp4l[644.862]: master offset -644 s2 freq +3870 path delay 3019
ptp4l[645.862]: master offset -402 s2 freq +3919 path delay 2978
ptp4l[646.863]: master offset -103 s2 freq +4097 path delay 2978
ptp4l[647.863]: master offset -157 s2 freq +4012 path delay 3001
ptp4l[648.863]: master offset -350 s2 freq +3772 path delay 3042
ptp4l[649.863]: master offset 126 s2 freq +4143 path delay 3021
ptp4l[650.863]: master offset 40 s2 freq +4095 path delay 3021


在1588 slave的打印中可以看到,slave先选择外部时钟master 000a35.fffe.04d238。当外部master退出后,再选择了本地时钟,0651e5.fffe.c27188。当外部master正常后,又选择了外部时钟master 000a35.fffe.04d238。


时钟的标识,是网卡的MAC地址。


master offset表示主从端时间差,单位是ns。s0,s1,s2 : 表示1588的不同状态,s0表示未锁定,s1表示正在同步,s2表示锁定。


2
PC机上运行1588

也可以在PC机上运行1588。首先在master和slave的PC机安装1588的Linux用户态应用程序,Linuxptp。

hankf@XSZGS4:~$ sudo apt install linuxptp
Reading package lists... Done
Building dependency tree
Reading state information... Done
The following packages were automatically installed and are no longer required:
libfwup1 libllvm9 linux-hwe-5.4-headers-5.4.0-51 linux-hwe-5.4-headers-5.4.0-52 linux-hwe-5.4-headers-5.4.0-53 linux-hwe-5.4-headers-5.4.0-56 linux-hwe-5.4-headers-5.4.0-58
linux-hwe-5.4-headers-5.4.0-59 linux-hwe-5.4-headers-5.4.0-60 linux-hwe-5.4-headers-5.4.0-62 linux-hwe-5.4-headers-5.4.0-65 linux-hwe-5.4-headers-5.4.0-66 linux-hwe-5.4-headers-5.4.0-67
Use 'sudo apt autoremove' to remove them.
The following NEW packages will be installed:
linuxptp
0 upgraded, 1 newly installed, 0 to remove and 18 not upgraded.
Need to get 112 kB of archives.
After this operation, 418 kB of additional disk space will be used.
Get:1 http://hk.archive.ubuntu.com/ubuntu bionic/universe amd64 linuxptp amd64 1.8-1 [112 kB]
Fetched 112 kB in 3s (33.0 kB/s)
Selecting previously unselected package linuxptp.
(Reading database ... 477696 files and directories currently installed.)
Preparing to unpack .../linuxptp_1.8-1_amd64.deb ...
Unpacking linuxptp (1.8-1) ...
Setting up linuxptp (1.8-1) ...
Processing triggers for man-db (2.8.3-2ubuntu0.1) ...


2.1. master
然后运行1588 master。

hankf@XSZGS4:~$ sudo ptp4l -i ens12f2 -m
[sudo] password for hankf:
ptp4l[4247020.499]: selected /dev/ptp4 as PTP clock
ptp4l[4247020.500]: driver changed our HWTSTAMP options
ptp4l[4247020.500]: tx_type 1 not 1
ptp4l[4247020.500]: rx_filter 1 not 12
ptp4l[4247020.500]: port 1: INITIALIZING to LISTENING on INITIALIZE
ptp4l[4247020.500]: port 0: INITIALIZING to LISTENING on INITIALIZE
ptp4l[4247020.501]: port 1: link up
ptp4l[4247028.079]: port 1: LISTENING to MASTER on ANNOUNCE_RECEIPT_TIMEOUT_EXPIRES
ptp4l[4247028.079]: selected best master clock 6c92bf.fffe.ccc500
ptp4l[4247028.079]: assuming the grand master role
^C
hankf@XSZGS4:~$


2.2. Slave
运行1588 Slave。

xilinx@xszgs2:~$ ifconfig eno3
eno3: flags=4163 mtu 1500
inet 10.164.177.202 netmask 255.255.255.0 broadcast 10.164.177.255
inet6 fe80::f56c:dc30:fa49:b101 prefixlen 64 scopeid 0x20
ether d0:94:66:55:0d:e9 txqueuelen 1000 (Ethernet)
RX packets 39897217 bytes 48144750947 (48.1 GB)
RX errors 107 dropped 6 overruns 107 frame 0
TX packets 14982002 bytes 4367094180 (4.3 GB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
device interrupt 42 memory 0x9e800000-9effffff

xilinx@xszgs2:~$ ptp4l -i eno3 -s -m
ptp4l[3650610.080]: selected /dev/ptp2 as PTP clock
ptp4l[3650610.081]: Failed to open /dev/ptp2: Permission denied
failed to create a clock
xilinx@xszgs2:~$ sudo ptp4l -i eno3 -s -m
ptp4l[3650613.052]: selected /dev/ptp2 as PTP clock
ptp4l[3650613.071]: port 1: INITIALIZING to LISTENING on INITIALIZE
ptp4l[3650613.071]: port 0: INITIALIZING to LISTENING on INITIALIZE
ptp4l[3650613.072]: port 1: link up
ptp4l[3650614.597]: port 1: new foreign master 6c92bf.fffe.ccc500-1
ptp4l[3650618.597]: selected best master clock 6c92bf.fffe.ccc500
ptp4l[3650618.597]: port 1: LISTENING to UNCALIBRATED on RS_SLAVE
ptp4l[3650620.597]: master offset -496821638515 s0 freq +0 path delay 25928
ptp4l[3650621.597]: master offset -496821663985 s1 freq -25469 path delay 22934
ptp4l[3650622.597]: master offset -3011 s2 freq -28480 path delay 22934
ptp4l[3650622.599]: port 1: UNCALIBRATED to SLAVE on MASTER_CLOCK_SELECTED
ptp4l[3650623.596]: master offset 6729 s2 freq -19643 path delay 13071
ptp4l[3650624.596]: master offset -2000 s2 freq -26353 path delay 13071
ptp4l[3650625.596]: master offset -4376 s2 freq -29329 path delay 13297
ptp4l[3650626.596]: master offset -3468 s2 freq -29734 path delay 13071
ptp4l[3650627.596]: master offset -2191 s2 freq -29498 path delay 13071
ptp4l[3650628.596]: master offset -994 s2 freq -28958 path delay 12936
ptp4l[3650629.596]: master offset -435 s2 freq -28697 path delay 12874
ptp4l[3650630.596]: master offset -380 s2 freq -28773 path delay 12874
ptp4l[3650631.596]: master offset -176 s2 freq -28683 path delay 12874
ptp4l[3650632.596]: master offset 161 s2 freq -28398 path delay 12874


在1588 slave的打印中可以看到,PC机上slave报告的master offset和path delay,都远远大于在zcu106之间运行1588的数据。



3
参考文档

MPSoC Ethernet Macb Driver(链接点击“阅读原文查看”)





扫码关注我们
关注电子元件技术,了解最新的产品技术资讯。

扫码申请加入电子元件技术交流圈

FPGA开发圈 这里介绍、交流、有关FPGA开发资料(文档下载,技术解答等),提升FPGA应用能力。
评论 (0)
  • 在智慧城市领域中,当一个智慧路灯项目因信号盲区而被迫增设数百个网关时,当一个传感器网络因入网设备数量爆增而导致系统通信失效时,当一个智慧交通系统因基站故障而导致交通瘫痪时,星型网络拓扑与蜂窝网络拓扑在构建广覆盖与高节点数物联网网络时的局限性便愈发凸显,行业内亟需一种更高效、可靠与稳定的组网技术以满足构建智慧城市海量IoT网络节点的需求。星型网络的无线信号覆盖范围高度依赖网关的部署密度,同时单一网关的承载设备数量有限,难以支撑海量IoT网络节点的城市物联系统;而蜂窝网络的无线信号覆盖范围同样高度依
    华普微HOPERF 2025-03-24 17:00 76浏览
  • 在人工智能与物联网技术蓬勃发展的今天,语音交互已成为智能设备的重要功能。广州唯创电子推出的WT3000T8语音合成芯片凭借其高性能、低功耗和灵活的控制方式,广泛应用于智能家居、工业设备、公共服务终端等领域。本文将从功能特点、调用方法及实际应用场景入手,深入解析这款芯片的核心技术。一、WT3000T8芯片的核心功能WT3000T8是一款基于UART通信的语音合成芯片,支持中文、英文及多语种混合文本的实时合成。其核心优势包括:高兼容性:支持GB2312/GBK/BIG5/UNICODE编码,适应不同
    广州唯创电子 2025-03-24 08:42 79浏览
  • 人形机器人产业节奏预估:2024年原型机元年,2025年小规模量产元年。当宇树科技H1人形机器人以灵动的手部动作在春晚舞台上演创意融合舞蹈《秧Bot》,舞出"中国智造"时,电视机前十几亿观众第一次深刻意识到:那个需要仰望波士顿动力的时代正在落幕。*图源:宇树科技短短数周后,宇树G1机器人又用一段丝滑的街舞在网络收割亿级播放量,钢铁之躯跳出赛博朋克的浪漫。2月11日,宇树科技在其京东官方旗舰店上架了两款人形机器人产品,型号分别为Unitree H1和G1。2月12日,9.9万元的G1人形机器人首批
    艾迈斯欧司朗 2025-03-22 21:05 89浏览
  • 在科技飞速发展的今天,视频监控领域对于高清、稳定、多功能解码芯片的需求与日俱增。现在,一款具有划时代意义的解码芯片——XS9922B 震撼登场,它将为车载监控、倒车影像等应用场景带来全新的变革体验。多协议支持,高清标清一网打尽,XS9922B 作为一款 4 通道模拟复合视频解码芯片,拥有强大的协议兼容性。它不仅支持 HDCCTV 高清协议,让你轻松捕捉高清画面的每一个细节,还兼容 CVBS 标清协议,满足不同设备和场景的多样化需求。无论是 720P/1080P 的高清制式,还是 960H/D1
    芯片徐15652902508 2025-03-21 13:58 20浏览
  • 无论你是刚步入职场的新人,还是已经有几年经验的职场老手,培养领导力都是职业发展中一个至关重要的环节。拥有良好的领导能力不仅能让你从人群中脱颖而出,也能让你在团队中成为一个值得信赖、富有影响力的核心成员。什么是领导力?领导力并不仅仅意味着“当老板”或者“发号施令”。它更多地是一种能够影响他人、激发团队潜能,并带领大家实现目标的能力。一位优秀的领导者需要具备清晰的沟通能力、解决问题的能力,以及对人心的深刻理解。他们知道如何激励人心,如何在压力下保持冷静,并能在关键时刻做出正确的决策。如何培养领导力?
    优思学院 2025-03-23 12:24 66浏览
  • 在智能终端设备快速普及的当下,语音交互已成为提升用户体验的关键功能。广州唯创电子推出的WT3000T8语音合成芯片,凭借其卓越的语音处理能力、灵活的控制模式及超低功耗设计,成为工业控制、商业终端、公共服务等领域的理想选择。本文将从技术特性、场景适配及成本优势三方面,解析其如何助力行业智能化转型。一、核心技术优势:精准、稳定、易集成1. 高品质语音输出,适配复杂环境音频性能:支持8kbps~320kbps宽范围比特率,兼容MP3/WAV格式,音质清晰自然,无机械感。大容量存储:内置Flash最大支
    广州唯创电子 2025-03-24 09:08 108浏览
  • 文/Leon编辑/cc孙聪颖‍去年,百度公关部副总裁璩静的争议言论闹得沸沸扬扬,最终以道歉离职收场。时隔一年,百度的高管又出事了。近日,“百度副总裁谢广军女儿开盒孕妇”事件登上热搜,持续发酵,引起网友对百度数据安全性的怀疑。3月19日晚间,百度正式发布声明,表示坚决谴责窃取和公开他人隐私的网络暴力行为,同时强调,百度内部实施匿名化、假名化处理,经查验,泄露数据并非来自百度,而是海外的社工库,“当事人承认家长给她数据库”为不实信息,针对相关谣言百度已经向公安机关报案。然而,并非所有网友都对这份声明
    华尔街科技眼 2025-03-21 21:21 70浏览
  • 精益管理的理念和思维是源于日本的丰田模式,虽然精益管理有很多有效而丰有智慧的思想和方法,但在欧美企业要应用精益也并不容易,始终东西方的文化、人民习性都会存在着一点差异。不过,客观来说,精益管理是其优缺点的,以下,优思学院[1]综合吉朱·安东尼(Jiju Antony)教授《中小企业精益六西格玛》一书中的研究略作说明。精益的优点以下是精益生产系统的一些优点(Schonberger,2008):1)积极的劳动力效应。精益战略往往基于员工的主动性,那些从事实际工作的员工才是改善工作的最具创造力的人员。
    优思学院 2025-03-21 15:09 25浏览
  • 核心板简介创龙科技 SOM-TL3562 是一款基于瑞芯微 RK3562J/RK3562 处理器设计的四核 ARM C ortex-A53 + 单核 ARM Cortex-M0 全国产工业核心板,主频高达 2.0GHz。核心板 CPU、R OM、RAM、电源、晶振等所有元器件均采用国产工业级方案,国产化率 100%。核心板通过 LCC 邮票孔 + LGA 封装连接方式引出 MAC、GMAC、PCIe 2.1、USB3.0、 CAN、UART、SPI、MIPI CSI、MIPI
    Tronlong 2025-03-24 09:59 103浏览
  • 文/郭楚妤编辑/cc孙聪颖‍在人工智能与实体经济深度融合的时代浪潮中,究竟何种 AI 产品,方能切实契合用户对美好未来的向往与期待?3 月 20 日,备受全球瞩目的中国家电及消费电子博览会(AWE2025)于上海新国际博览中心盛大开幕。展会首日,长虹重磅推出首款治愈系 AI TV、客餐厅 PRO 共享空调,以及面向低空经济领域的通信模组等一系列创新产品。这一举动充分展现了长虹在家电领域全面推进 AI 化的坚定决心,以及为低空经济等新兴产业提供有力科技支撑的硬核实力 。“首发” 新品,领航用户价值
    华尔街科技眼 2025-03-21 21:13 44浏览
  • 近年来,随着半导体产业的快速发展和技术的不断迭代,物联网设备种类繁多(如智能家居、工业传感器),对算力、功耗、实时性要求差异大,单一架构无法满足所有需求。因此米尔推出MYD-YT113i开发板(基于全志T113-i)来应对这一市场需求。米尔基于全志T113-i核心板及开发板part 01  T113-i芯片及OpenAMP简介T113-i芯片简介T113-i由两颗ARM A7 、一颗C906(RISC-V)和一颗DSP(HIFI 4)组成。C906(RISC-V核)特性:主频
    米尔电子嵌入式 2025-03-21 16:28 30浏览
  • 很多时候我们会以价值来衡量一个人或一件事,也很容易以成败来论定其价值;所谓胜者为王败者为寇,同样的一个人,在成功时是一种评价,如若失败,所得到的又是另一种评断。古训有云:「不以成败论英雄」,成败得失只是一时的胜负,决定胜败的因素很多,无论人、事、时、地、物,都能影响最后的结果,然而结果却不一定是真正最终的价值论断。好比历史上名垂千古的楚汉之争,刘邦最终得胜,开国立业成为汉高祖,然而,刘邦的为人处事、风格操守或是韬略能力,真的就强于项羽吗?其实,刘邦若无萧何、韩信等人鼎力相辅,若非民心一面倒向刘邦
    优思学院 2025-03-21 12:08 27浏览
  • 今年全国两会期间,“体重管理”和“育儿”整体配套政策引发了持久广泛关注。从“吃”到“养”,都围绕着国人最为关心的话题:健康。大家常说“病从口入”,在吃这件事上,过去大家可能更多是为了填饱肚子,如今,消费者从挑选食材到厨电都贯彻着健康的宗旨,吃得少了更要吃得好了。这也意味着在新消费趋势下,谁能抓住众人的心头好,就能带起众人的购买欲望,才能在新一轮竞争中脱颖而出。作为家电行业的风向标,在2025年中国家电及消费电子博览会(AWE)上,这两个话题也被媒体和公众频繁提及。深耕中国厨房三十余年的苏泊尔再次
    华尔街科技眼 2025-03-22 11:42 46浏览
  • 文/Leon编辑/cc孙聪颖‍“无AI,不家电”的浪潮,正在席卷整个家电行业。中国家电及消费电子博览会(AWE2025)期间,几乎所有的企业,都展出了搭载最新AI大模型的产品,从电视、洗衣机、冰箱等黑白电,到扫地机器人、双足机器人,AI渗透率之高令人惊喜。此番景象,不仅让人思考:AI对于家电的真正意义是什么,具体体现在哪些方面?作为全球家电巨头,海信给出了颇有大智慧的答案:AI化繁为简,将复杂留给技术、把简单还给生活,是海信对于AI 家电的终极答案。在AWE上,海信发布了一系列世俱杯新品,发力家
    华尔街科技眼 2025-03-23 20:46 58浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦