#ifndef __KSZ_COMMON_H
#define __KSZ_COMMON_H
#include <linux/etherdevice.h>
#include <linux/kernel.h>
#include <linux/mutex.h>
#include <linux/phy.h>
#include <linux/regmap.h>
#include <net/dsa.h>
#include <linux/irq.h>
#include <linux/platform_data/microchip-ksz.h>
#include "ksz_ptp.h"
#define KSZ_MAX_NUM_PORTS …
#define KSZ_PORT_1 …
#define KSZ_PORT_2 …
#define KSZ_PORT_4 …
struct ksz_device;
struct ksz_port;
struct phylink_mac_ops;
enum ksz_regmap_width { … };
struct vlan_table { … };
struct ksz_port_mib { … };
struct ksz_mib_names { … };
struct ksz_chip_data { … };
struct ksz_irq { … };
struct ksz_ptp_irq { … };
struct ksz_switch_macaddr { … };
struct ksz_port { … };
struct ksz_device { … };
enum ksz_model { … };
enum ksz_regs { … };
enum ksz_masks { … };
enum ksz_shifts { … };
enum ksz_xmii_ctrl0 { … };
enum ksz_xmii_ctrl1 { … };
struct alu_struct { … };
struct ksz_dev_ops { … };
struct ksz_device *ksz_switch_alloc(struct device *base, void *priv);
int ksz_switch_register(struct ksz_device *dev);
void ksz_switch_remove(struct ksz_device *dev);
void ksz_init_mib_timer(struct ksz_device *dev);
bool ksz_is_port_mac_global_usable(struct dsa_switch *ds, int port);
void ksz_r_mib_stats64(struct ksz_device *dev, int port);
void ksz88xx_r_mib_stats64(struct ksz_device *dev, int port);
void ksz_port_stp_state_set(struct dsa_switch *ds, int port, u8 state);
bool ksz_get_gbit(struct ksz_device *dev, int port);
phy_interface_t ksz_get_xmii(struct ksz_device *dev, int port, bool gbit);
extern const struct ksz_chip_data ksz_switch_chips[];
int ksz_switch_macaddr_get(struct dsa_switch *ds, int port,
struct netlink_ext_ack *extack);
void ksz_switch_macaddr_put(struct dsa_switch *ds);
void ksz_switch_shutdown(struct ksz_device *dev);
int ksz_handle_wake_reason(struct ksz_device *dev, int port);
static inline struct regmap *ksz_regmap_8(struct ksz_device *dev)
{ … }
static inline struct regmap *ksz_regmap_16(struct ksz_device *dev)
{ … }
static inline struct regmap *ksz_regmap_32(struct ksz_device *dev)
{ … }
static inline int ksz_read8(struct ksz_device *dev, u32 reg, u8 *val)
{ … }
static inline int ksz_read16(struct ksz_device *dev, u32 reg, u16 *val)
{ … }
static inline int ksz_read32(struct ksz_device *dev, u32 reg, u32 *val)
{ … }
static inline int ksz_read64(struct ksz_device *dev, u32 reg, u64 *val)
{ … }
static inline int ksz_write8(struct ksz_device *dev, u32 reg, u8 value)
{ … }
static inline int ksz_write16(struct ksz_device *dev, u32 reg, u16 value)
{ … }
static inline int ksz_write32(struct ksz_device *dev, u32 reg, u32 value)
{ … }
static inline int ksz_rmw16(struct ksz_device *dev, u32 reg, u16 mask,
u16 value)
{ … }
static inline int ksz_rmw32(struct ksz_device *dev, u32 reg, u32 mask,
u32 value)
{ … }
static inline int ksz_write64(struct ksz_device *dev, u32 reg, u64 value)
{ … }
static inline int ksz_rmw8(struct ksz_device *dev, int offset, u8 mask, u8 val)
{ … }
static inline int ksz_pread8(struct ksz_device *dev, int port, int offset,
u8 *data)
{ … }
static inline int ksz_pread16(struct ksz_device *dev, int port, int offset,
u16 *data)
{ … }
static inline int ksz_pread32(struct ksz_device *dev, int port, int offset,
u32 *data)
{ … }
static inline int ksz_pwrite8(struct ksz_device *dev, int port, int offset,
u8 data)
{ … }
static inline int ksz_pwrite16(struct ksz_device *dev, int port, int offset,
u16 data)
{ … }
static inline int ksz_pwrite32(struct ksz_device *dev, int port, int offset,
u32 data)
{ … }
static inline int ksz_prmw8(struct ksz_device *dev, int port, int offset,
u8 mask, u8 val)
{ … }
static inline int ksz_prmw32(struct ksz_device *dev, int port, int offset,
u32 mask, u32 val)
{ … }
static inline void ksz_regmap_lock(void *__mtx)
{ … }
static inline void ksz_regmap_unlock(void *__mtx)
{ … }
static inline bool ksz_is_ksz87xx(struct ksz_device *dev)
{ … }
static inline bool ksz_is_ksz88x3(struct ksz_device *dev)
{ … }
static inline bool ksz_is_8895_family(struct ksz_device *dev)
{ … }
static inline bool is_ksz8(struct ksz_device *dev)
{ … }
static inline bool is_ksz88xx(struct ksz_device *dev)
{ … }
static inline bool is_ksz9477(struct ksz_device *dev)
{ … }
static inline int is_lan937x(struct ksz_device *dev)
{ … }
static inline bool is_lan937x_tx_phy(struct ksz_device *dev, int port)
{ … }
#define PORT_TX_ENABLE …
#define PORT_RX_ENABLE …
#define PORT_LEARN_DISABLE …
#define REG_CHIP_ID0 …
#define SW_FAMILY_ID_M …
#define KSZ87_FAMILY_ID …
#define KSZ88_FAMILY_ID …
#define KSZ8895_FAMILY_ID …
#define KSZ8_PORT_STATUS_0 …
#define KSZ8_PORT_FIBER_MODE …
#define SW_CHIP_ID_M …
#define KSZ87_CHIP_ID_94 …
#define KSZ87_CHIP_ID_95 …
#define KSZ88_CHIP_ID_63 …
#define KSZ8895_CHIP_ID_95 …
#define KSZ8895_CHIP_ID_95R …
#define REG_KSZ8864_CHIP_ID …
#define SW_KSZ8864 …
#define SW_REV_ID_M …
#define REG_CHIP_ID4 …
#define SKU_ID_KSZ8563 …
#define SKU_ID_KSZ9563 …
#define BROADCAST_STORM_PROT_RATE …
#define BROADCAST_STORM_VALUE …
#define BROADCAST_STORM_RATE_HI …
#define BROADCAST_STORM_RATE_LO …
#define BROADCAST_STORM_RATE …
#define MULTICAST_STORM_DISABLE …
#define SW_START …
#define P_MII_DUPLEX_M …
#define P_MII_100MBIT_M …
#define P_GMII_1GBIT_M …
#define P_RGMII_ID_IG_ENABLE …
#define P_RGMII_ID_EG_ENABLE …
#define P_MII_MAC_MODE …
#define P_MII_SEL_M …
#define PME_WOL_MAGICPKT …
#define PME_WOL_LINKUP …
#define PME_WOL_ENERGY …
#define PME_ENABLE …
#define PME_POLARITY …
#define KSZ87XX_REG_INT_EN …
#define KSZ87XX_INT_PME_MASK …
#define REG_SW_PORT_INT_STATUS__1 …
#define REG_SW_PORT_INT_MASK__1 …
#define REG_PORT_INT_STATUS …
#define REG_PORT_INT_MASK …
#define PORT_SRC_PHY_INT …
#define PORT_SRC_PTP_INT …
#define KSZ8795_HUGE_PACKET_SIZE …
#define KSZ8863_HUGE_PACKET_SIZE …
#define KSZ8863_NORMAL_PACKET_SIZE …
#define KSZ8_LEGAL_PACKET_SIZE …
#define KSZ9477_MAX_FRAME_SIZE …
#define KSZ8873_REG_GLOBAL_CTRL_12 …
#define KSZ8873_DRIVE_STRENGTH_16MA …
#define KSZ8795_REG_SW_CTRL_20 …
#define KSZ9477_REG_SW_IO_STRENGTH …
#define SW_DRIVE_STRENGTH_M …
#define SW_DRIVE_STRENGTH_2MA …
#define SW_DRIVE_STRENGTH_4MA …
#define SW_DRIVE_STRENGTH_8MA …
#define SW_DRIVE_STRENGTH_12MA …
#define SW_DRIVE_STRENGTH_16MA …
#define SW_DRIVE_STRENGTH_20MA …
#define SW_DRIVE_STRENGTH_24MA …
#define SW_DRIVE_STRENGTH_28MA …
#define SW_HI_SPEED_DRIVE_STRENGTH_S …
#define SW_LO_SPEED_DRIVE_STRENGTH_S …
#define KSZ9477_REG_PORT_OUT_RATE_0 …
#define KSZ9477_OUT_RATE_NO_LIMIT …
#define KSZ9477_PORT_MRI_TC_MAP__4 …
#define KSZ9477_PORT_TC_MAP_S …
#define REG_PORT_MTI_QUEUE_INDEX__4 …
#define REG_PORT_MTI_QUEUE_CTRL_0 …
#define MTI_SCHEDULE_MODE_M …
#define MTI_SCHEDULE_STRICT_PRIO …
#define MTI_SCHEDULE_WRR …
#define MTI_SHAPING_M …
#define MTI_SHAPING_OFF …
#define MTI_SHAPING_SRP …
#define MTI_SHAPING_TIME_AWARE …
#define KSZ9477_PORT_MTI_QUEUE_CTRL_1 …
#define KSZ9477_DEFAULT_WRR_WEIGHT …
#define REG_PORT_MTI_HI_WATER_MARK …
#define REG_PORT_MTI_LO_WATER_MARK …
#define KSZ_SPI_OP_RD …
#define KSZ_SPI_OP_WR …
#define swabnot_used(x) …
#define KSZ_SPI_OP_FLAG_MASK(opcode, swp, regbits, regpad) …
#define KSZ_REGMAP_ENTRY(width, swp, regbits, regpad, regalign) …
#define KSZ_REGMAP_TABLE(ksz, swp, regbits, regpad, regalign) …
#endif