有没有办法禁用 Intel I211 Gigabit w/igb 驱动程序上的精确时间协议 (PTP)?

有没有办法禁用 Intel I211 Gigabit w/igb 驱动程序上的精确时间协议 (PTP)?

我有一块华硕 Pro WS X570-ACE 主板,搭载 AMD Ryzen 5700G,板载 Intel I211 以太网,运行驱动程序 igb 版本 5.11.0-27。它还配有 Realtek 板载以太网,但在 BIOS 中已禁用。操作系统是 Linux Mint 20.2,运行内核 5.11.0-27-generic。

每当操作系统启动时,“dmesg”输出中都会显示以下内容:

 pps_core: LinuxPPS API ver. 1 registered
 pps_core: Software ver. 5.3.6 - Copyright 2005-2007 Rodolfo Giometti <[email protected]>
 pps pps0: new PPS source ptp0
 pps_ldisc: PPS line discipline registered

出现 2 个设备:/dev/pps0 和 /dev/ptp0

我知道是 Intel I211 端口在执行此操作,因为如果我ethtool -T enp5s0在适配器上运行,它会显示:

Time stamping parameters for enp5s0:
Capabilities:
    hardware-transmit     (SOF_TIMESTAMPING_TX_HARDWARE)
    software-transmit     (SOF_TIMESTAMPING_TX_SOFTWARE)
    hardware-receive      (SOF_TIMESTAMPING_RX_HARDWARE)
    software-receive      (SOF_TIMESTAMPING_RX_SOFTWARE)
    software-system-clock (SOF_TIMESTAMPING_SOFTWARE)
    hardware-raw-clock    (SOF_TIMESTAMPING_RAW_HARDWARE)
PTP Hardware Clock: 0
Hardware Transmit Timestamp Modes:
    off                   (HWTSTAMP_TX_OFF)
    on                    (HWTSTAMP_TX_ON)
Hardware Receive Filter Modes:
    none                  (HWTSTAMP_FILTER_NONE)
    all                   (HWTSTAMP_FILTER_ALL)

这意味着PTP Hardware Clock: 0 这将创建 /dev/ptp0,从而创建 /dev/pps0。以下是 /dev/ 中相关设备的列表:

/dev/port  /dev/ppp  /dev/pps0  /dev/pps1  /dev/psaux  /dev/ptmx  /dev/ptp0  /dev/ptp1  /dev/ptp2

这个 PTP 对我来说是个问题的原因是我使用 GPS 接收器来设置时间。

我有一个通过板载 COM/Serial DB9 连接器连接的 GPS 接收器,我使用它通过串行接口将每秒脉冲 (PPS) 输入到引脚 1,从而将计算机上的时间设置为微秒精度。GPSD 和 CHRONY 负责其余部分...但问题是,由于 PTP,GPSD 在 /dev/pps1 而不是 /dev/pps0 创建了 PPS 设备。GPSD 通常认为其 PPS 源是 /dev/pps0。如果我在命令行中指定将 /dev/pps1 用作 PPS 源,GPSD 确实可以工作...但与完全没有 PTP 的计算机相比,锁定和同步需要多花几分钟...

pps_core: LinuxPPS API ver. 1 registered
pps_core: Software ver. 5.3.6 - Copyright 2005-2007 Rodolfo Giometti <[email protected]>
pps pps0: new PPS source ptp0
pps_ldisc: PPS line discipline registered
pps pps1: new PPS source serial0
pps pps1: source "/dev/ttyS0" added

我查看了 Ethtool 手册和 Intel IGB 驱动程序构建指南,但没有可设置关闭 HARDWARE_TIMESTAMPS 的参数。Ethtool 仅有 -T 开关,显示时间戳功能……但没有可通过 ethtool -T/-t 设置的实际选项。

问题:有没有办法可以彻底禁用这个 PTP 系统?

答案1

2011 年左右添加了支持某些英特尔卡上的 HC 的代码。英特尔® 以太网控制器 I211-AT支持基于硬件的精确时间同步。启用它是因为模块开发人员这样考虑:(来源

如果 MAC 具有 PTP 功能,那么用户肯定会希望启用它。

简而言之:你的结论是正确的。不过,你仍然可以做几件事:

  • 联系模块开发人员并展示您的用例。说服他们,即使通常认为某个功能是需要的并且默认启用,也有充分的理由禁用该功能。
  • 重新编译已删除 HC 的模块。
  • 尝试使用 Realtek NIC。
  • 尝试配置 gpsd 以忽略设备,/dev/pps0或者/dev/ptp0- 根据文档应该是可能的:

要告诉守护进程某个设备已断开连接并且不再可用,请发送减号(“-”),后跟设备名称,后跟 LF 或 CR-LF。因此,要从搜索列表中删除 /dev/foo,请发送“-/dev/foo\n”。

通过修改下的文件,这也应该可以自动完成/etc/gpsd/device-hook

相关内容