2019-05-19 20:07:45 +08:00
|
|
|
# SPDX-License-Identifier: GPL-2.0-only
|
2011-04-22 18:03:08 +08:00
|
|
|
#
|
|
|
|
# PTP clock support configuration
|
|
|
|
#
|
|
|
|
|
|
|
|
menu "PTP clock support"
|
|
|
|
|
|
|
|
config PTP_1588_CLOCK
|
|
|
|
tristate "PTP clock support"
|
posix-timers: Make them configurable
Some embedded systems have no use for them. This removes about
25KB from the kernel binary size when configured out.
Corresponding syscalls are routed to a stub logging the attempt to
use those syscalls which should be enough of a clue if they were
disabled without proper consideration. They are: timer_create,
timer_gettime: timer_getoverrun, timer_settime, timer_delete,
clock_adjtime, setitimer, getitimer, alarm.
The clock_settime, clock_gettime, clock_getres and clock_nanosleep
syscalls are replaced by simple wrappers compatible with CLOCK_REALTIME,
CLOCK_MONOTONIC and CLOCK_BOOTTIME only which should cover the vast
majority of use cases with very little code.
Signed-off-by: Nicolas Pitre <nico@linaro.org>
Acked-by: Richard Cochran <richardcochran@gmail.com>
Acked-by: Thomas Gleixner <tglx@linutronix.de>
Acked-by: John Stultz <john.stultz@linaro.org>
Reviewed-by: Josh Triplett <josh@joshtriplett.org>
Cc: Paul Bolle <pebolle@tiscali.nl>
Cc: linux-kbuild@vger.kernel.org
Cc: netdev@vger.kernel.org
Cc: Michal Marek <mmarek@suse.com>
Cc: Edward Cree <ecree@solarflare.com>
Link: http://lkml.kernel.org/r/1478841010-28605-7-git-send-email-nicolas.pitre@linaro.org
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
2016-11-11 13:10:10 +08:00
|
|
|
depends on NET && POSIX_TIMERS
|
2012-10-31 23:32:44 +08:00
|
|
|
select PPS
|
2014-04-01 22:20:23 +08:00
|
|
|
select NET_PTP_CLASSIFY
|
2011-04-22 18:03:08 +08:00
|
|
|
help
|
|
|
|
The IEEE 1588 standard defines a method to precisely
|
|
|
|
synchronize distributed clocks over Ethernet networks. The
|
|
|
|
standard defines a Precision Time Protocol (PTP), which can
|
|
|
|
be used to achieve synchronization within a few dozen
|
|
|
|
microseconds. In addition, with the help of special hardware
|
|
|
|
time stamping units, it can be possible to achieve
|
|
|
|
synchronization to within a few hundred nanoseconds.
|
|
|
|
|
|
|
|
This driver adds support for PTP clocks as character
|
|
|
|
devices. If you want to use a PTP clock, then you should
|
|
|
|
also enable at least one clock driver as well.
|
|
|
|
|
|
|
|
To compile this driver as a module, choose M here: the module
|
|
|
|
will be called ptp.
|
|
|
|
|
2017-06-13 04:26:01 +08:00
|
|
|
config PTP_1588_CLOCK_DTE
|
|
|
|
tristate "Broadcom DTE as PTP clock"
|
|
|
|
depends on PTP_1588_CLOCK
|
|
|
|
depends on NET && HAS_IOMEM
|
|
|
|
depends on ARCH_BCM_MOBILE || (ARCH_BCM_IPROC && !(ARCH_BCM_NSP || ARCH_BCM_5301X)) || COMPILE_TEST
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
This driver adds support for using the Digital timing engine
|
|
|
|
(DTE) in the Broadcom SoC's as a PTP clock.
|
|
|
|
|
|
|
|
The clock can be used in both wired and wireless networks
|
|
|
|
for PTP purposes.
|
|
|
|
|
|
|
|
To compile this driver as a module, choose M here: the module
|
|
|
|
will be called ptp_dte.
|
|
|
|
|
2018-05-25 12:40:34 +08:00
|
|
|
config PTP_1588_CLOCK_QORIQ
|
|
|
|
tristate "Freescale QorIQ 1588 timer as PTP clock"
|
2019-06-14 18:40:50 +08:00
|
|
|
depends on GIANFAR || FSL_DPAA_ETH || FSL_DPAA2_ETH || FSL_ENETC || FSL_ENETC_VF || COMPILE_TEST
|
2016-11-11 13:10:07 +08:00
|
|
|
depends on PTP_1588_CLOCK
|
2012-10-31 23:33:52 +08:00
|
|
|
default y
|
2011-04-22 18:03:54 +08:00
|
|
|
help
|
2018-05-25 12:40:34 +08:00
|
|
|
This driver adds support for using the Freescale QorIQ 1588
|
|
|
|
timer as a PTP clock. This clock is only useful if your PTP
|
|
|
|
programs are getting hardware time stamps on the PTP Ethernet
|
|
|
|
packets using the SO_TIMESTAMPING API.
|
2011-04-22 18:03:54 +08:00
|
|
|
|
|
|
|
To compile this driver as a module, choose M here: the module
|
2019-01-21 18:41:42 +08:00
|
|
|
will be called ptp-qoriq.
|
2011-04-22 18:03:54 +08:00
|
|
|
|
2011-04-22 18:04:55 +08:00
|
|
|
comment "Enable PHYLIB and NETWORK_PHY_TIMESTAMPING to see the additional clocks."
|
2012-10-31 23:33:52 +08:00
|
|
|
depends on PHYLIB=n || NETWORK_PHY_TIMESTAMPING=n
|
2011-04-22 18:04:55 +08:00
|
|
|
|
|
|
|
config DP83640_PHY
|
|
|
|
tristate "Driver for the National Semiconductor DP83640 PHYTER"
|
|
|
|
depends on NETWORK_PHY_TIMESTAMPING
|
|
|
|
depends on PHYLIB
|
2016-11-11 13:10:07 +08:00
|
|
|
depends on PTP_1588_CLOCK
|
2011-04-22 18:04:55 +08:00
|
|
|
---help---
|
|
|
|
Supports the DP83640 PHYTER with IEEE 1588 features.
|
|
|
|
|
|
|
|
This driver adds support for using the DP83640 as a PTP
|
|
|
|
clock. This clock is only useful if your PTP programs are
|
|
|
|
getting hardware time stamps on the PTP Ethernet packets
|
|
|
|
using the SO_TIMESTAMPING API.
|
|
|
|
|
|
|
|
In order for this to work, your MAC driver must also
|
2012-04-13 23:14:11 +08:00
|
|
|
implement the skb_tx_timestamp() function.
|
2011-04-22 18:04:55 +08:00
|
|
|
|
2019-12-26 10:16:20 +08:00
|
|
|
config PTP_1588_CLOCK_INES
|
|
|
|
tristate "ZHAW InES PTP time stamping IP core"
|
|
|
|
depends on NETWORK_PHY_TIMESTAMPING
|
|
|
|
depends on PHYLIB
|
|
|
|
depends on PTP_1588_CLOCK
|
|
|
|
help
|
|
|
|
This driver adds support for using the ZHAW InES 1588 IP
|
|
|
|
core. This clock is only useful if the MII bus of your MAC
|
|
|
|
is wired up to the core.
|
|
|
|
|
2012-03-08 06:16:26 +08:00
|
|
|
config PTP_1588_CLOCK_PCH
|
|
|
|
tristate "Intel PCH EG20T as PTP clock"
|
2014-06-17 17:59:20 +08:00
|
|
|
depends on X86_32 || COMPILE_TEST
|
2014-05-09 05:54:42 +08:00
|
|
|
depends on HAS_IOMEM && NET
|
2016-11-11 13:10:07 +08:00
|
|
|
imply PTP_1588_CLOCK
|
2012-03-08 06:16:26 +08:00
|
|
|
help
|
|
|
|
This driver adds support for using the PCH EG20T as a PTP
|
2012-04-21 02:50:34 +08:00
|
|
|
clock. The hardware supports time stamping of PTP packets
|
2019-10-07 23:43:02 +08:00
|
|
|
when using the end-to-end delay (E2E) mechanism. The peer
|
|
|
|
delay mechanism (P2P) is not supported.
|
2012-04-21 02:50:34 +08:00
|
|
|
|
|
|
|
This clock is only useful if your PTP programs are getting
|
|
|
|
hardware time stamps on the PTP Ethernet packets using the
|
|
|
|
SO_TIMESTAMPING API.
|
2012-03-08 06:16:26 +08:00
|
|
|
|
|
|
|
To compile this driver as a module, choose M here: the module
|
|
|
|
will be called ptp_pch.
|
|
|
|
|
2017-01-25 01:09:42 +08:00
|
|
|
config PTP_1588_CLOCK_KVM
|
|
|
|
tristate "KVM virtual PTP clock"
|
|
|
|
depends on PTP_1588_CLOCK
|
|
|
|
depends on KVM_GUEST && X86
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
This driver adds support for using kvm infrastructure as a PTP
|
|
|
|
clock. This clock is only useful if you are using KVM guests.
|
|
|
|
|
|
|
|
To compile this driver as a module, choose M here: the module
|
|
|
|
will be called ptp_kvm.
|
|
|
|
|
2020-02-22 04:03:51 +08:00
|
|
|
config PTP_1588_CLOCK_IDT82P33
|
|
|
|
tristate "IDT 82P33xxx PTP clock"
|
|
|
|
depends on PTP_1588_CLOCK && I2C
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
This driver adds support for using the IDT 82P33xxx as a PTP
|
|
|
|
clock. This clock is only useful if your time stamping MAC
|
|
|
|
is connected to the IDT chip.
|
|
|
|
|
|
|
|
To compile this driver as a module, choose M here: the module
|
|
|
|
will be called ptp_idt82p33.
|
|
|
|
|
2019-11-01 11:20:07 +08:00
|
|
|
config PTP_1588_CLOCK_IDTCM
|
|
|
|
tristate "IDT CLOCKMATRIX as PTP clock"
|
2019-12-11 03:56:34 +08:00
|
|
|
depends on PTP_1588_CLOCK && I2C
|
2019-11-01 11:20:07 +08:00
|
|
|
default n
|
|
|
|
help
|
|
|
|
This driver adds support for using IDT CLOCKMATRIX(TM) as a PTP
|
|
|
|
clock. This clock is only useful if your time stamping MAC
|
|
|
|
is connected to the IDT chip.
|
|
|
|
|
|
|
|
To compile this driver as a module, choose M here: the module
|
|
|
|
will be called ptp_clockmatrix.
|
|
|
|
|
2011-04-22 18:03:08 +08:00
|
|
|
endmenu
|