|
Thomas Bogendoerfer |
0245fc |
From: Naveen Mamindlapalli <naveenm@marvell.com>
|
|
Thomas Bogendoerfer |
0245fc |
Date: Sat, 10 Sep 2022 13:24:13 +0530
|
|
Thomas Bogendoerfer |
0245fc |
Subject: octeontx2-af: return correct ptp timestamp for CN10K silicon
|
|
Thomas Bogendoerfer |
0245fc |
Patch-mainline: v6.1-rc1
|
|
Thomas Bogendoerfer |
0245fc |
Git-commit: a8025e7946a2b18c4ac17b36fde528d2f6262bdd
|
|
Thomas Bogendoerfer |
0245fc |
References: jsc#SLE-24682
|
|
Thomas Bogendoerfer |
0245fc |
|
|
Thomas Bogendoerfer |
0245fc |
The MIO_PTP_TIMESTAMP format has been changed in CN10K silicon
|
|
Thomas Bogendoerfer |
0245fc |
family. The upper 32-bits represents seconds and lower 32-bits
|
|
Thomas Bogendoerfer |
0245fc |
represents nanoseconds. This patch returns nanosecond timestamp
|
|
Thomas Bogendoerfer |
0245fc |
to NIX PF driver.
|
|
Thomas Bogendoerfer |
0245fc |
|
|
Thomas Bogendoerfer |
0245fc |
Signed-off-by: Naveen Mamindlapalli <naveenm@marvell.com>
|
|
Thomas Bogendoerfer |
0245fc |
Signed-off-by: Sunil Kovvuri Goutham <sgoutham@marvell.com>
|
|
Thomas Bogendoerfer |
0245fc |
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
Thomas Bogendoerfer |
0245fc |
Acked-by: Thomas Bogendoerfer <tbogendoerfer@suse.de>
|
|
Thomas Bogendoerfer |
0245fc |
---
|
|
Thomas Bogendoerfer |
0245fc |
drivers/net/ethernet/marvell/octeontx2/af/ptp.c | 14 +++++++++++++-
|
|
Thomas Bogendoerfer |
0245fc |
1 file changed, 13 insertions(+), 1 deletion(-)
|
|
Thomas Bogendoerfer |
0245fc |
|
|
Thomas Bogendoerfer |
0245fc |
--- a/drivers/net/ethernet/marvell/octeontx2/af/ptp.c
|
|
Thomas Bogendoerfer |
0245fc |
+++ b/drivers/net/ethernet/marvell/octeontx2/af/ptp.c
|
|
Thomas Bogendoerfer |
0245fc |
@@ -56,6 +56,11 @@
|
|
Thomas Bogendoerfer |
0245fc |
static struct ptp *first_ptp_block;
|
|
Thomas Bogendoerfer |
0245fc |
static const struct pci_device_id ptp_id_table[];
|
|
Thomas Bogendoerfer |
0245fc |
|
|
Thomas Bogendoerfer |
0245fc |
+static bool is_ptp_dev_cn10k(struct ptp *ptp)
|
|
Thomas Bogendoerfer |
0245fc |
+{
|
|
Thomas Bogendoerfer |
0245fc |
+ return (ptp->pdev->device == PCI_DEVID_CN10K_PTP) ? true : false;
|
|
Thomas Bogendoerfer |
0245fc |
+}
|
|
Thomas Bogendoerfer |
0245fc |
+
|
|
Thomas Bogendoerfer |
0245fc |
static bool cn10k_ptp_errata(struct ptp *ptp)
|
|
Thomas Bogendoerfer |
0245fc |
{
|
|
Thomas Bogendoerfer |
0245fc |
if (ptp->pdev->subsystem_device == PCI_SUBSYS_DEVID_CN10K_A_PTP ||
|
|
Thomas Bogendoerfer |
0245fc |
@@ -282,7 +287,14 @@ void ptp_start(struct ptp *ptp, u64 sclk
|
|
Thomas Bogendoerfer |
0245fc |
|
|
Thomas Bogendoerfer |
0245fc |
static int ptp_get_tstmp(struct ptp *ptp, u64 *clk)
|
|
Thomas Bogendoerfer |
0245fc |
{
|
|
Thomas Bogendoerfer |
0245fc |
- *clk = readq(ptp->reg_base + PTP_TIMESTAMP);
|
|
Thomas Bogendoerfer |
0245fc |
+ u64 timestamp;
|
|
Thomas Bogendoerfer |
0245fc |
+
|
|
Thomas Bogendoerfer |
0245fc |
+ if (is_ptp_dev_cn10k(ptp)) {
|
|
Thomas Bogendoerfer |
0245fc |
+ timestamp = readq(ptp->reg_base + PTP_TIMESTAMP);
|
|
Thomas Bogendoerfer |
0245fc |
+ *clk = (timestamp >> 32) * NSEC_PER_SEC + (timestamp & 0xFFFFFFFF);
|
|
Thomas Bogendoerfer |
0245fc |
+ } else {
|
|
Thomas Bogendoerfer |
0245fc |
+ *clk = readq(ptp->reg_base + PTP_TIMESTAMP);
|
|
Thomas Bogendoerfer |
0245fc |
+ }
|
|
Thomas Bogendoerfer |
0245fc |
|
|
Thomas Bogendoerfer |
0245fc |
return 0;
|
|
Thomas Bogendoerfer |
0245fc |
}
|