linux/drivers/net/phy/mscc/mscc_ptp.c

// SPDX-License-Identifier: (GPL-2.0 OR MIT)
/*
 * Driver for Microsemi VSC85xx PHYs - timestamping and PHC support
 *
 * Authors: Quentin Schulz & Antoine Tenart
 * License: Dual MIT/GPL
 * Copyright (c) 2020 Microsemi Corporation
 */

#include <linux/gpio/consumer.h>
#include <linux/ip.h>
#include <linux/net_tstamp.h>
#include <linux/mii.h>
#include <linux/phy.h>
#include <linux/ptp_classify.h>
#include <linux/ptp_clock_kernel.h>
#include <linux/udp.h>
#include <linux/unaligned.h>

#include "mscc.h"
#include "mscc_ptp.h"

/* Two PHYs share the same 1588 processor and it's to be entirely configured
 * through the base PHY of this processor.
 */
/* phydev->bus->mdio_lock should be locked when using this function */
static int phy_ts_base_write(struct phy_device *phydev, u32 regnum, u16 val)
{}

/* phydev->bus->mdio_lock should be locked when using this function */
static int phy_ts_base_read(struct phy_device *phydev, u32 regnum)
{}

enum ts_blk_hw {};

enum ts_blk {};

static u32 vsc85xx_ts_read_csr(struct phy_device *phydev, enum ts_blk blk,
			       u16 addr)
{}

static void vsc85xx_ts_write_csr(struct phy_device *phydev, enum ts_blk blk,
				 u16 addr, u32 val)
{}

/* Pick bytes from PTP header */
#define PTP_HEADER_TRNSP_MSG
#define PTP_HEADER_DOMAIN_NUM
#define PTP_HEADER_BYTE_8_31(x)
#define MAC_ADDRESS_BYTE(x)

static int vsc85xx_ts_fsb_init(struct phy_device *phydev)
{}

static const u32 vsc85xx_egr_latency[] =;

static const u32 vsc85xx_egr_latency_macsec[] =;

static const u32 vsc85xx_ingr_latency[] =;

static const u32 vsc85xx_ingr_latency_macsec[] =;

static void vsc85xx_ts_set_latencies(struct phy_device *phydev)
{}

static int vsc85xx_ts_disable_flows(struct phy_device *phydev, enum ts_blk blk)
{}

static int vsc85xx_ts_eth_cmp1_sig(struct phy_device *phydev)
{}

static struct vsc85xx_ptphdr *get_ptp_header_l4(struct sk_buff *skb,
						struct iphdr *iphdr,
						struct udphdr *udphdr)
{}

static struct vsc85xx_ptphdr *get_ptp_header_tx(struct sk_buff *skb)
{}

static struct vsc85xx_ptphdr *get_ptp_header_rx(struct sk_buff *skb,
						enum hwtstamp_rx_filters rx_filter)
{}

static int get_sig(struct sk_buff *skb, u8 *sig)
{}

static void vsc85xx_dequeue_skb(struct vsc85xx_ptp *ptp)
{}

static void vsc85xx_get_tx_ts(struct vsc85xx_ptp *ptp)
{}

static int vsc85xx_ptp_cmp_init(struct phy_device *phydev, enum ts_blk blk)
{}

static int vsc85xx_eth_cmp1_init(struct phy_device *phydev, enum ts_blk blk)
{}

static int vsc85xx_ip_cmp1_init(struct phy_device *phydev, enum ts_blk blk)
{}

static int vsc85xx_adjfine(struct ptp_clock_info *info, long scaled_ppm)
{}

static int __vsc85xx_gettime(struct ptp_clock_info *info, struct timespec64 *ts)
{}

static int vsc85xx_gettime(struct ptp_clock_info *info, struct timespec64 *ts)
{}

static int __vsc85xx_settime(struct ptp_clock_info *info,
			     const struct timespec64 *ts)
{}

static int vsc85xx_settime(struct ptp_clock_info *info,
			   const struct timespec64 *ts)
{}

static int vsc85xx_adjtime(struct ptp_clock_info *info, s64 delta)
{}

static int vsc85xx_eth1_next_comp(struct phy_device *phydev, enum ts_blk blk,
				  u32 next_comp, u32 etype)
{}

static int vsc85xx_ip1_next_comp(struct phy_device *phydev, enum ts_blk blk,
				 u32 next_comp, u32 header)
{}

static int vsc85xx_ts_ptp_action_flow(struct phy_device *phydev, enum ts_blk blk, u8 flow, enum ptp_cmd cmd)
{}

static int vsc85xx_ptp_conf(struct phy_device *phydev, enum ts_blk blk,
			    bool one_step, bool enable)
{}

static int vsc85xx_eth1_conf(struct phy_device *phydev, enum ts_blk blk,
			     bool enable)
{}

static int vsc85xx_ip1_conf(struct phy_device *phydev, enum ts_blk blk,
			    bool enable)
{}

static int vsc85xx_ts_engine_init(struct phy_device *phydev, bool one_step)
{}

void vsc85xx_link_change_notify(struct phy_device *phydev)
{}

static void vsc85xx_ts_reset_fifo(struct phy_device *phydev)
{}

static int vsc85xx_hwtstamp(struct mii_timestamper *mii_ts,
			    struct kernel_hwtstamp_config *cfg,
			    struct netlink_ext_ack *extack)
{}

static int vsc85xx_ts_info(struct mii_timestamper *mii_ts,
			   struct kernel_ethtool_ts_info *info)
{}

static void vsc85xx_txtstamp(struct mii_timestamper *mii_ts,
			     struct sk_buff *skb, int type)
{}

static bool vsc85xx_rxtstamp(struct mii_timestamper *mii_ts,
			     struct sk_buff *skb, int type)
{}

static const struct ptp_clock_info vsc85xx_clk_caps =;

static struct vsc8531_private *vsc8584_base_priv(struct phy_device *phydev)
{}

static bool vsc8584_is_1588_input_clk_configured(struct phy_device *phydev)
{}

static void vsc8584_set_input_clk_configured(struct phy_device *phydev)
{}

static int __vsc8584_init_ptp(struct phy_device *phydev)
{}

void vsc8584_config_ts_intr(struct phy_device *phydev)
{}

int vsc8584_ptp_init(struct phy_device *phydev)
{}

irqreturn_t vsc8584_handle_ts_interrupt(struct phy_device *phydev)
{}

int vsc8584_ptp_probe(struct phy_device *phydev)
{}

int vsc8584_ptp_probe_once(struct phy_device *phydev)
{}