mirror of
git://nv-tegra.nvidia.com/linux-nv-oot.git
synced 2025-12-23 17:55:05 +03:00
Add support for r8126 ethernet driverversion 10.013.00-NAPI-PTP which adds support for PTP and supports till K6.9 Bug 4478230 Change-Id: I381d3689a188e5d365ff89092a98023eeaa2a095 Signed-off-by: Revanth Kumar Uppala <ruppala@nvidia.com> Reviewed-on: https://git-master.nvidia.com/r/c/linux-nv-oot/+/3151529 Tested-by: Sandipan Patra <spatra@nvidia.com> Reviewed-by: Shobek Attupurath <sattupurath@nvidia.com> Reviewed-by: Bitan Biswas <bbiswas@nvidia.com> Reviewed-by: Sandipan Patra <spatra@nvidia.com>
114 lines
3.5 KiB
C
114 lines
3.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
################################################################################
|
|
#
|
|
# r8126 is the Linux device driver released for Realtek 5 Gigabit Ethernet
|
|
# controllers with PCI-Express interface.
|
|
#
|
|
# Copyright(c) 2024 Realtek Semiconductor Corp. All rights reserved.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify it
|
|
# under the terms of the GNU General Public License as published by the Free
|
|
# Software Foundation; either version 2 of the License, or (at your option)
|
|
# any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
# more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along with
|
|
# this program; if not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
# Author:
|
|
# Realtek NIC software team <nicfae@realtek.com>
|
|
# No. 2, Innovation Road II, Hsinchu Science Park, Hsinchu 300, Taiwan
|
|
#
|
|
################################################################################
|
|
*/
|
|
|
|
/************************************************************************************
|
|
* This product is covered by one or more of the following patents:
|
|
* US6,570,884, US6,115,776, and US6,327,625.
|
|
***********************************************************************************/
|
|
|
|
#ifndef _LINUX_R8126_PTP_H
|
|
#define _LINUX_R8126_PTP_H
|
|
|
|
#include <linux/ktime.h>
|
|
#include <linux/timecounter.h>
|
|
#include <linux/net_tstamp.h>
|
|
#include <linux/ptp_clock_kernel.h>
|
|
#include <linux/ptp_classify.h>
|
|
|
|
struct rtl8126_ptp_info {
|
|
s64 time_sec;
|
|
u32 time_ns;
|
|
u16 ts_info;
|
|
};
|
|
|
|
#ifndef _STRUCT_TIMESPEC
|
|
#define _STRUCT_TIMESPEC
|
|
struct timespec {
|
|
__kernel_old_time_t tv_sec; /* seconds */
|
|
long tv_nsec; /* nanoseconds */
|
|
};
|
|
#endif
|
|
|
|
enum PTP_CMD_TYPE {
|
|
PTP_CMD_SET_LOCAL_TIME = 0,
|
|
PTP_CMD_DRIFT_LOCAL_TIME,
|
|
PTP_CMD_LATCHED_LOCAL_TIME,
|
|
};
|
|
|
|
enum PTP_CLKADJ_MOD_TYPE {
|
|
NO_FUNCTION = 0,
|
|
CLKADJ_MODE_SET = 1,
|
|
RESERVED = 2,
|
|
DIRECT_READ = 4,
|
|
DIRECT_WRITE = 6,
|
|
INCREMENT_STEP = 8,
|
|
DECREMENT_STEP = 10,
|
|
RATE_READ = 12,
|
|
RATE_WRITE = 14,
|
|
};
|
|
|
|
enum PTP_INSR_TYPE {
|
|
EVENT_CAP_INTR = (1 << 0),
|
|
TRIG_GEN_INTR = (1 << 1),
|
|
RX_TS_INTR = (1 << 2),
|
|
TX_TX_INTR = (1 << 3),
|
|
};
|
|
|
|
enum PTP_TRX_TS_STA_REG {
|
|
TRX_TS_RD = (1 << 0),
|
|
TRXTS_SEL = (1 << 1),
|
|
RX_TS_PDLYRSP_RDY = (1 << 8),
|
|
RX_TS_PDLYREQ_RDY = (1 << 9),
|
|
RX_TS_DLYREQ_RDY = (1 << 10),
|
|
RX_TS_SYNC_RDY = (1 << 11),
|
|
TX_TS_PDLYRSP_RDY = (1 << 12),
|
|
TX_TS_PDLYREQ_RDY = (1 << 13),
|
|
TX_TS_DLYREQ_RDY = (1 << 14),
|
|
TX_TS_SYNC_RDY = (1 << 15),
|
|
};
|
|
|
|
struct rtl8126_private;
|
|
struct RxDescV3;
|
|
|
|
int rtl8126_get_ts_info(struct net_device *netdev,
|
|
struct ethtool_ts_info *info);
|
|
|
|
void rtl8126_ptp_reset(struct rtl8126_private *tp);
|
|
void rtl8126_ptp_init(struct rtl8126_private *tp);
|
|
void rtl8126_ptp_suspend(struct rtl8126_private *tp);
|
|
void rtl8126_ptp_stop(struct rtl8126_private *tp);
|
|
|
|
int rtl8126_ptp_ioctl(struct net_device *netdev, struct ifreq *ifr, int cmd);
|
|
|
|
void rtl8126_rx_ptp_pktstamp(struct rtl8126_private *tp, struct sk_buff *skb);
|
|
|
|
void rtl8126_set_local_time(struct rtl8126_private *tp);
|
|
|
|
#endif /* _LINUX_R8126_PTP_H */
|