1 /* SPDX-License-Identifier: GPL-2.0 */ 2 /* Microchip lan937x dev ops headers 3 * Copyright (C) 2019-2022 Microchip Technology Inc. 4 */ 5 6 #ifndef __LAN937X_CFG_H 7 #define __LAN937X_CFG_H 8 9 int lan937x_reset_switch(struct ksz_device *dev); 10 int lan937x_setup(struct dsa_switch *ds); 11 void lan937x_port_setup(struct ksz_device *dev, int port, bool cpu_port); 12 void lan937x_config_cpu_port(struct dsa_switch *ds); 13 int lan937x_switch_init(struct ksz_device *dev); 14 void lan937x_switch_exit(struct ksz_device *dev); 15 void lan937x_r_phy(struct ksz_device *dev, u16 addr, u16 reg, u16 *data); 16 void lan937x_w_phy(struct ksz_device *dev, u16 addr, u16 reg, u16 val); 17 int lan937x_change_mtu(struct ksz_device *dev, int port, int new_mtu); 18 void lan937x_phylink_get_caps(struct ksz_device *dev, int port, 19 struct phylink_config *config); 20 void lan937x_phylink_mac_link_up(struct ksz_device *dev, int port, 21 unsigned int mode, phy_interface_t interface, 22 struct phy_device *phydev, int speed, 23 int duplex, bool tx_pause, bool rx_pause); 24 void lan937x_phylink_mac_config(struct ksz_device *dev, int port, 25 unsigned int mode, 26 const struct phylink_link_state *state); 27 #endif 28