/* SPDX-License-Identifier: GPL-2.0+ */ /* * Copyright (C) 2015 Freescale Semiconductor */ #ifndef __LDPAA_WRIOP_H #define __LDPAA_WRIOP_H #include <phy.h> #define DEFAULT_WRIOP_MDIO1_NAME "FSL_MDIO0" #define DEFAULT_WRIOP_MDIO2_NAME "FSL_MDIO1" #define WRIOP_MAX_PHY_NUM 2 enum wriop_port { WRIOP1_DPMAC1 = 1, WRIOP1_DPMAC2, WRIOP1_DPMAC3, WRIOP1_DPMAC4, WRIOP1_DPMAC5, WRIOP1_DPMAC6, WRIOP1_DPMAC7, WRIOP1_DPMAC8, WRIOP1_DPMAC9, WRIOP1_DPMAC10, WRIOP1_DPMAC11, WRIOP1_DPMAC12, WRIOP1_DPMAC13, WRIOP1_DPMAC14, WRIOP1_DPMAC15, WRIOP1_DPMAC16, WRIOP1_DPMAC17, WRIOP1_DPMAC18, WRIOP1_DPMAC19, WRIOP1_DPMAC20, WRIOP1_DPMAC21, WRIOP1_DPMAC22, WRIOP1_DPMAC23, WRIOP1_DPMAC24, NUM_WRIOP_PORTS, }; struct wriop_dpmac_info { u8 enabled; u8 id; u8 board_mux; int phy_addr[WRIOP_MAX_PHY_NUM]; phy_interface_t enet_if; struct phy_device *phydev[WRIOP_MAX_PHY_NUM]; struct mii_dev *bus; }; extern struct wriop_dpmac_info dpmac_info[NUM_WRIOP_PORTS]; void wriop_init_dpmac(int sd, int dpmac_id, int lane_prtcl); void wriop_init_dpmac_enet_if(int dpmac_id, phy_interface_t enet_if); int wriop_disable_dpmac(int dpmac_id); int wriop_enable_dpmac(int dpmac_id); int wriop_is_enabled_dpmac(int dpmac_id); int wriop_set_mdio(int dpmac_id, struct mii_dev *bus); struct mii_dev *wriop_get_mdio(int dpmac_id); int wriop_set_phy_address(int dpmac_id, int phy_num, int address); int wriop_get_phy_address(int dpmac_id, int phy_num); int wriop_set_phy_dev(int dpmac_id, int phy_num, struct phy_device *phydev); struct phy_device *wriop_get_phy_dev(int dpmac_id, int phy_num); phy_interface_t wriop_get_enet_if(int dpmac_id); void wriop_dpmac_disable(int dpmac_id); void wriop_dpmac_enable(int dpmac_id); phy_interface_t wriop_dpmac_enet_if(int dpmac_id, int lane_prtcl); void wriop_init_dpmac_qsgmii(int sd, int lane_prtcl); void wriop_init_rgmii(void); #endif /* __LDPAA_WRIOP_H */