59 lines
1.8 KiB
C
59 lines
1.8 KiB
C
|
/* SPDX-License-Identifier: (GPL-2.0 OR MIT) */
|
||
|
/*
|
||
|
* DSA driver for:
|
||
|
* Hirschmann Hellcreek TSN switch.
|
||
|
*
|
||
|
* Copyright (C) 2019,2020 Hochschule Offenburg
|
||
|
* Copyright (C) 2019,2020 Linutronix GmbH
|
||
|
* Authors: Kurt Kanzenbach <kurt@linutronix.de>
|
||
|
* Kamil Alkhouri <kamil.alkhouri@hs-offenburg.de>
|
||
|
*/
|
||
|
|
||
|
#ifndef _HELLCREEK_HWTSTAMP_H_
|
||
|
#define _HELLCREEK_HWTSTAMP_H_
|
||
|
|
||
|
#include <net/dsa.h>
|
||
|
#include "hellcreek.h"
|
||
|
|
||
|
/* Timestamp Register */
|
||
|
#define PR_TS_RX_P1_STATUS_C (0x1d * 2)
|
||
|
#define PR_TS_RX_P1_DATA_C (0x1e * 2)
|
||
|
#define PR_TS_TX_P1_STATUS_C (0x1f * 2)
|
||
|
#define PR_TS_TX_P1_DATA_C (0x20 * 2)
|
||
|
#define PR_TS_RX_P2_STATUS_C (0x25 * 2)
|
||
|
#define PR_TS_RX_P2_DATA_C (0x26 * 2)
|
||
|
#define PR_TS_TX_P2_STATUS_C (0x27 * 2)
|
||
|
#define PR_TS_TX_P2_DATA_C (0x28 * 2)
|
||
|
|
||
|
#define PR_TS_STATUS_TS_AVAIL BIT(2)
|
||
|
#define PR_TS_STATUS_TS_LOST BIT(3)
|
||
|
|
||
|
#define SKB_PTP_TYPE(__skb) (*(unsigned int *)((__skb)->cb))
|
||
|
|
||
|
/* TX_TSTAMP_TIMEOUT: This limits the time spent polling for a TX
|
||
|
* timestamp. When working properly, hardware will produce a timestamp
|
||
|
* within 1ms. Software may enounter delays, so the timeout is set
|
||
|
* accordingly.
|
||
|
*/
|
||
|
#define TX_TSTAMP_TIMEOUT msecs_to_jiffies(40)
|
||
|
|
||
|
int hellcreek_port_hwtstamp_set(struct dsa_switch *ds, int port,
|
||
|
struct ifreq *ifr);
|
||
|
int hellcreek_port_hwtstamp_get(struct dsa_switch *ds, int port,
|
||
|
struct ifreq *ifr);
|
||
|
|
||
|
bool hellcreek_port_rxtstamp(struct dsa_switch *ds, int port,
|
||
|
struct sk_buff *clone, unsigned int type);
|
||
|
void hellcreek_port_txtstamp(struct dsa_switch *ds, int port,
|
||
|
struct sk_buff *skb);
|
||
|
|
||
|
int hellcreek_get_ts_info(struct dsa_switch *ds, int port,
|
||
|
struct ethtool_ts_info *info);
|
||
|
|
||
|
long hellcreek_hwtstamp_work(struct ptp_clock_info *ptp);
|
||
|
|
||
|
int hellcreek_hwtstamp_setup(struct hellcreek *chip);
|
||
|
void hellcreek_hwtstamp_free(struct hellcreek *chip);
|
||
|
|
||
|
#endif /* _HELLCREEK_HWTSTAMP_H_ */
|