我有一块华硕 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
。