Lines Matching full:slave
451 /* Some hw stat regs are applicable to slave port only.
459 u32 rx_pause_frames; /* slave */
461 u32 rx_align_code_errors; /* slave */
463 u32 rx_jabber_frames; /* slave */
465 u32 rx_fragments; /* slave */
472 u32 tx_pause_frames; /* slave */
473 u32 tx_deferred_frames; /* slave */
474 u32 tx_collision_frames; /* slave */
475 u32 tx_single_coll_frames; /* slave */
476 u32 tx_mult_coll_frames; /* slave */
477 u32 tx_excessive_collisions; /* slave */
478 u32 tx_late_collisions; /* slave */
479 u32 rx_ipg_error; /* slave 10G only */
480 u32 tx_carrier_sense_errors; /* slave */
764 struct gbe_slave *slave; member
1728 #define for_each_sec_slave(slave, priv) \ argument
1729 list_for_each_entry((slave), &(priv)->secondary_slaves, slave_list)
1944 if (!gbe_intf->slave) in keystone_get_link_ksettings()
1948 cmd->base.port = gbe_intf->slave->phy_port_t; in keystone_get_link_ksettings()
1976 if (!gbe_intf->slave) in keystone_set_link_ksettings()
1979 if (port != gbe_intf->slave->phy_port_t) { in keystone_set_link_ksettings()
1996 gbe_intf->slave->phy_port_t = port; in keystone_set_link_ksettings()
2051 static void gbe_set_slave_mac(struct gbe_slave *slave, in gbe_set_slave_mac() argument
2056 writel(mac_hi(ndev->dev_addr), GBE_REG_ADDR(slave, port_regs, sa_hi)); in gbe_set_slave_mac()
2057 writel(mac_lo(ndev->dev_addr), GBE_REG_ADDR(slave, port_regs, sa_lo)); in gbe_set_slave_mac()
2070 struct gbe_slave *slave, in netcp_ethss_link_state_action() argument
2073 struct phy_device *phy = slave->phy; in netcp_ethss_link_state_action()
2077 mac_control = slave->mac_control; in netcp_ethss_link_state_action()
2086 writel(mac_control, GBE_REG_ADDR(slave, emac_regs, in netcp_ethss_link_state_action()
2089 cpsw_ale_control_set(gbe_dev->ale, slave->port_num, in netcp_ethss_link_state_action()
2093 if (ndev && slave->open && in netcp_ethss_link_state_action()
2094 ((slave->link_interface != SGMII_LINK_MAC_PHY) && in netcp_ethss_link_state_action()
2095 (slave->link_interface != RGMII_LINK_MAC_PHY) && in netcp_ethss_link_state_action()
2096 (slave->link_interface != XGMII_LINK_MAC_PHY))) in netcp_ethss_link_state_action()
2099 writel(mac_control, GBE_REG_ADDR(slave, emac_regs, in netcp_ethss_link_state_action()
2101 cpsw_ale_control_set(gbe_dev->ale, slave->port_num, in netcp_ethss_link_state_action()
2105 ((slave->link_interface != SGMII_LINK_MAC_PHY) && in netcp_ethss_link_state_action()
2106 (slave->link_interface != RGMII_LINK_MAC_PHY) && in netcp_ethss_link_state_action()
2107 (slave->link_interface != XGMII_LINK_MAC_PHY))) in netcp_ethss_link_state_action()
2115 static bool gbe_phy_link_status(struct gbe_slave *slave) in gbe_phy_link_status() argument
2117 return !slave->phy || slave->phy->link; in gbe_phy_link_status()
2131 struct gbe_slave *slave, in netcp_ethss_update_link_state() argument
2135 int sp = slave->slave_num, link_state; in netcp_ethss_update_link_state()
2137 if (!slave->open) in netcp_ethss_update_link_state()
2140 if (SLAVE_LINK_IS_RGMII(slave)) in netcp_ethss_update_link_state()
2143 if (SLAVE_LINK_IS_SGMII(slave)) in netcp_ethss_update_link_state()
2147 phy_link_state = gbe_phy_link_status(slave); in netcp_ethss_update_link_state()
2150 if (atomic_xchg(&slave->link_state, link_state) != link_state) in netcp_ethss_update_link_state()
2151 netcp_ethss_link_state_action(gbe_dev, ndev, slave, in netcp_ethss_update_link_state()
2164 netcp_ethss_update_link_state(gbe_intf->gbe_dev, gbe_intf->slave, in xgbe_adjust_link()
2177 netcp_ethss_update_link_state(gbe_intf->gbe_dev, gbe_intf->slave, in gbe_adjust_link()
2184 struct gbe_slave *slave; in gbe_adjust_link_sec_slaves() local
2186 for_each_sec_slave(slave, gbe_dev) in gbe_adjust_link_sec_slaves()
2187 netcp_ethss_update_link_state(gbe_dev, slave, NULL); in gbe_adjust_link_sec_slaves()
2193 static int gbe_port_reset(struct gbe_slave *slave) in gbe_port_reset() argument
2198 writel(SOFT_RESET, GBE_REG_ADDR(slave, emac_regs, soft_reset)); in gbe_port_reset()
2202 v = readl(GBE_REG_ADDR(slave, emac_regs, soft_reset)); in gbe_port_reset()
2212 static void gbe_port_config(struct gbe_priv *gbe_dev, struct gbe_slave *slave, in gbe_port_config() argument
2223 (slave->link_interface >= XGMII_LINK_MAC_PHY)) { in gbe_port_config()
2225 xgmii_mode |= (1 << slave->slave_num); in gbe_port_config()
2230 rx_maxlen_reg = GBE_REG_ADDR(slave, port_regs, rx_maxlen); in gbe_port_config()
2232 rx_maxlen_reg = GBE_REG_ADDR(slave, emac_regs, rx_maxlen); in gbe_port_config()
2235 writel(slave->mac_control, GBE_REG_ADDR(slave, emac_regs, mac_control)); in gbe_port_config()
2239 struct gbe_slave *slave, bool set) in gbe_sgmii_rtreset() argument
2241 if (SLAVE_LINK_IS_XGMII(slave)) in gbe_sgmii_rtreset()
2244 netcp_sgmii_rtreset(SGMII_BASE(priv, slave->slave_num), in gbe_sgmii_rtreset()
2245 slave->slave_num, set); in gbe_sgmii_rtreset()
2251 struct gbe_slave *slave = intf->slave; in gbe_slave_stop() local
2254 gbe_sgmii_rtreset(gbe_dev, slave, true); in gbe_slave_stop()
2255 gbe_port_reset(slave); in gbe_slave_stop()
2257 cpsw_ale_control_set(gbe_dev->ale, slave->port_num, in gbe_slave_stop()
2260 1 << slave->port_num, 0, 0); in gbe_slave_stop()
2262 if (!slave->phy) in gbe_slave_stop()
2265 phy_stop(slave->phy); in gbe_slave_stop()
2266 phy_disconnect(slave->phy); in gbe_slave_stop()
2267 slave->phy = NULL; in gbe_slave_stop()
2270 static void gbe_sgmii_config(struct gbe_priv *priv, struct gbe_slave *slave) in gbe_sgmii_config() argument
2272 if (SLAVE_LINK_IS_XGMII(slave)) in gbe_sgmii_config()
2275 netcp_sgmii_reset(SGMII_BASE(priv, slave->slave_num), slave->slave_num); in gbe_sgmii_config()
2276 netcp_sgmii_config(SGMII_BASE(priv, slave->slave_num), slave->slave_num, in gbe_sgmii_config()
2277 slave->link_interface); in gbe_sgmii_config()
2283 struct gbe_slave *slave = gbe_intf->slave; in gbe_slave_open() local
2291 gbe_sgmii_config(priv, slave); in gbe_slave_open()
2292 gbe_port_reset(slave); in gbe_slave_open()
2294 gbe_sgmii_rtreset(priv, slave, false); in gbe_slave_open()
2295 gbe_port_config(priv, slave, priv->rx_packet_max); in gbe_slave_open()
2296 gbe_set_slave_mac(slave, gbe_intf); in gbe_slave_open()
2302 GBE_REG_ADDR(slave, port_regs, rx_pri_map)); in gbe_slave_open()
2305 cpsw_ale_control_set(priv->ale, slave->port_num, in gbe_slave_open()
2308 1 << slave->port_num, 0, 0, ALE_MCAST_FWD_2); in gbe_slave_open()
2310 if (slave->link_interface == SGMII_LINK_MAC_PHY) { in gbe_slave_open()
2313 slave->phy_port_t = PORT_MII; in gbe_slave_open()
2314 } else if (slave->link_interface == RGMII_LINK_MAC_PHY) { in gbe_slave_open()
2316 err = of_get_phy_mode(slave->node, &phy_mode); in gbe_slave_open()
2328 slave->phy_port_t = PORT_MII; in gbe_slave_open()
2329 } else if (slave->link_interface == XGMII_LINK_MAC_PHY) { in gbe_slave_open()
2332 slave->phy_port_t = PORT_FIBRE; in gbe_slave_open()
2339 slave->phy = of_phy_connect(gbe_intf->ndev, in gbe_slave_open()
2340 slave->phy_node, in gbe_slave_open()
2343 if (!slave->phy) { in gbe_slave_open()
2344 dev_err(priv->dev, "phy not found on slave %d\n", in gbe_slave_open()
2345 slave->slave_num); in gbe_slave_open()
2349 phydev_name(slave->phy)); in gbe_slave_open()
2350 phy_start(slave->phy); in gbe_slave_open()
2613 struct gbe_slave *slave = gbe_intf->slave; in gbe_hwtstamp() local
2618 writel(0, GBE_REG_ADDR(slave, port_regs, ts_ctl)); in gbe_hwtstamp()
2625 (slave->ts_ctl.dst_port_map << TS_CTL_DST_PORT_SHIFT) | in gbe_hwtstamp()
2626 (slave->ts_ctl.uni ? TS_UNI_EN : in gbe_hwtstamp()
2627 slave->ts_ctl.maddr_map << TS_CTL_MADDR_SHIFT); in gbe_hwtstamp()
2635 writel(ts_en, GBE_REG_ADDR(slave, port_regs, ts_ctl)); in gbe_hwtstamp()
2636 writel(seq_id, GBE_REG_ADDR(slave, port_regs, ts_seq_ltype)); in gbe_hwtstamp()
2637 writel(ctl, GBE_REG_ADDR(slave, port_regs, ts_ctl_ltype2)); in gbe_hwtstamp()
2817 struct phy_device *phy = gbe_intf->slave->phy; in gbe_ioctl()
2838 struct gbe_slave *slave; in netcp_ethss_timer() local
2842 if (!gbe_intf->slave->open) in netcp_ethss_timer()
2844 netcp_ethss_update_link_state(gbe_dev, gbe_intf->slave, in netcp_ethss_timer()
2849 for_each_sec_slave(slave, gbe_dev) { in netcp_ethss_timer()
2850 netcp_ethss_update_link_state(gbe_dev, slave, NULL); in netcp_ethss_timer()
2888 struct gbe_slave *slave = gbe_intf->slave; in gbe_open() local
2889 int port_num = slave->port_num; in gbe_open()
2938 slave->open = true; in gbe_open()
2939 netcp_ethss_update_link_state(gbe_dev, slave, ndev); in gbe_open()
2963 gbe_intf->slave->open = false; in gbe_close()
2964 atomic_set(&gbe_intf->slave->link_state, NETCP_LINK_STATE_INVALID); in gbe_close()
2969 static void init_slave_ts_ctl(struct gbe_slave *slave) in init_slave_ts_ctl() argument
2971 slave->ts_ctl.uni = 1; in init_slave_ts_ctl()
2972 slave->ts_ctl.dst_port_map = in init_slave_ts_ctl()
2974 slave->ts_ctl.maddr_map = in init_slave_ts_ctl()
2979 static void init_slave_ts_ctl(struct gbe_slave *slave) in init_slave_ts_ctl() argument
2984 static int init_slave(struct gbe_priv *gbe_dev, struct gbe_slave *slave, in init_slave() argument
2991 if (of_property_read_u32(node, "slave-port", &slave->slave_num)) { in init_slave()
2992 dev_err(gbe_dev->dev, "missing slave-port parameter\n"); in init_slave()
2997 &slave->link_interface)) { in init_slave()
3000 slave->link_interface = SGMII_LINK_MAC_PHY; in init_slave()
3003 slave->node = node; in init_slave()
3004 slave->open = false; in init_slave()
3005 if ((slave->link_interface == SGMII_LINK_MAC_PHY) || in init_slave()
3006 (slave->link_interface == RGMII_LINK_MAC_PHY) || in init_slave()
3007 (slave->link_interface == XGMII_LINK_MAC_PHY)) in init_slave()
3008 slave->phy_node = of_parse_phandle(node, "phy-handle", 0); in init_slave()
3009 slave->port_num = gbe_get_slave_port(gbe_dev, slave->slave_num); in init_slave()
3011 if (slave->link_interface >= XGMII_LINK_MAC_PHY) in init_slave()
3012 slave->mac_control = GBE_DEF_10G_MAC_CONTROL; in init_slave()
3014 slave->mac_control = GBE_DEF_1G_MAC_CONTROL; in init_slave()
3017 port_reg_num = slave->slave_num; in init_slave()
3019 if (slave->slave_num > 1) { in init_slave()
3044 slave->port_regs = gbe_dev->switch_regs + port_reg_ofs + in init_slave()
3046 slave->emac_regs = gbe_dev->switch_regs + emac_reg_ofs + in init_slave()
3047 (emac_reg_blk_sz * slave->slave_num); in init_slave()
3050 /* Initialize slave port register offsets */ in init_slave()
3051 GBE_SET_REG_OFS(slave, port_regs, port_vlan); in init_slave()
3052 GBE_SET_REG_OFS(slave, port_regs, tx_pri_map); in init_slave()
3053 GBE_SET_REG_OFS(slave, port_regs, sa_lo); in init_slave()
3054 GBE_SET_REG_OFS(slave, port_regs, sa_hi); in init_slave()
3055 GBE_SET_REG_OFS(slave, port_regs, ts_ctl); in init_slave()
3056 GBE_SET_REG_OFS(slave, port_regs, ts_seq_ltype); in init_slave()
3057 GBE_SET_REG_OFS(slave, port_regs, ts_vlan); in init_slave()
3058 GBE_SET_REG_OFS(slave, port_regs, ts_ctl_ltype2); in init_slave()
3059 GBE_SET_REG_OFS(slave, port_regs, ts_ctl2); in init_slave()
3062 GBE_SET_REG_OFS(slave, emac_regs, mac_control); in init_slave()
3063 GBE_SET_REG_OFS(slave, emac_regs, soft_reset); in init_slave()
3064 GBE_SET_REG_OFS(slave, emac_regs, rx_maxlen); in init_slave()
3067 /* Initialize slave port register offsets */ in init_slave()
3068 GBENU_SET_REG_OFS(slave, port_regs, port_vlan); in init_slave()
3069 GBENU_SET_REG_OFS(slave, port_regs, tx_pri_map); in init_slave()
3070 GBENU_SET_REG_OFS(slave, port_regs, rx_pri_map); in init_slave()
3071 GBENU_SET_REG_OFS(slave, port_regs, sa_lo); in init_slave()
3072 GBENU_SET_REG_OFS(slave, port_regs, sa_hi); in init_slave()
3073 GBENU_SET_REG_OFS(slave, port_regs, ts_ctl); in init_slave()
3074 GBENU_SET_REG_OFS(slave, port_regs, ts_seq_ltype); in init_slave()
3075 GBENU_SET_REG_OFS(slave, port_regs, ts_vlan); in init_slave()
3076 GBENU_SET_REG_OFS(slave, port_regs, ts_ctl_ltype2); in init_slave()
3077 GBENU_SET_REG_OFS(slave, port_regs, ts_ctl2); in init_slave()
3078 GBENU_SET_REG_OFS(slave, port_regs, rx_maxlen); in init_slave()
3081 GBENU_SET_REG_OFS(slave, emac_regs, mac_control); in init_slave()
3082 GBENU_SET_REG_OFS(slave, emac_regs, soft_reset); in init_slave()
3085 /* Initialize slave port register offsets */ in init_slave()
3086 XGBE_SET_REG_OFS(slave, port_regs, port_vlan); in init_slave()
3087 XGBE_SET_REG_OFS(slave, port_regs, tx_pri_map); in init_slave()
3088 XGBE_SET_REG_OFS(slave, port_regs, sa_lo); in init_slave()
3089 XGBE_SET_REG_OFS(slave, port_regs, sa_hi); in init_slave()
3090 XGBE_SET_REG_OFS(slave, port_regs, ts_ctl); in init_slave()
3091 XGBE_SET_REG_OFS(slave, port_regs, ts_seq_ltype); in init_slave()
3092 XGBE_SET_REG_OFS(slave, port_regs, ts_vlan); in init_slave()
3093 XGBE_SET_REG_OFS(slave, port_regs, ts_ctl_ltype2); in init_slave()
3094 XGBE_SET_REG_OFS(slave, port_regs, ts_ctl2); in init_slave()
3097 XGBE_SET_REG_OFS(slave, emac_regs, mac_control); in init_slave()
3098 XGBE_SET_REG_OFS(slave, emac_regs, soft_reset); in init_slave()
3099 XGBE_SET_REG_OFS(slave, emac_regs, rx_maxlen); in init_slave()
3102 atomic_set(&slave->link_state, NETCP_LINK_STATE_INVALID); in init_slave()
3104 init_slave_ts_ctl(slave); in init_slave()
3115 struct gbe_slave *slave; in init_secondary_ports() local
3119 slave = devm_kzalloc(dev, sizeof(*slave), GFP_KERNEL); in init_secondary_ports()
3120 if (!slave) { in init_secondary_ports()
3126 if (init_slave(gbe_dev, slave, port)) { in init_secondary_ports()
3130 devm_kfree(dev, slave); in init_secondary_ports()
3135 gbe_sgmii_config(gbe_dev, slave); in init_secondary_ports()
3136 gbe_port_reset(slave); in init_secondary_ports()
3137 gbe_port_config(gbe_dev, slave, gbe_dev->rx_packet_max); in init_secondary_ports()
3138 list_add_tail(&slave->slave_list, &gbe_dev->secondary_slaves); in init_secondary_ports()
3140 if ((slave->link_interface == SGMII_LINK_MAC_PHY) || in init_secondary_ports()
3141 (slave->link_interface == XGMII_LINK_MAC_PHY)) in init_secondary_ports()
3144 slave->open = true; in init_secondary_ports()
3166 if (slave->link_interface == SGMII_LINK_MAC_PHY) { in init_secondary_ports()
3168 slave->phy_port_t = PORT_MII; in init_secondary_ports()
3169 } else if (slave->link_interface == RGMII_LINK_MAC_PHY) { in init_secondary_ports()
3171 slave->phy_port_t = PORT_MII; in init_secondary_ports()
3174 slave->phy_port_t = PORT_FIBRE; in init_secondary_ports()
3177 for_each_sec_slave(slave, gbe_dev) { in init_secondary_ports()
3178 if ((slave->link_interface != SGMII_LINK_MAC_PHY) && in init_secondary_ports()
3179 (slave->link_interface != RGMII_LINK_MAC_PHY) && in init_secondary_ports()
3180 (slave->link_interface != XGMII_LINK_MAC_PHY)) in init_secondary_ports()
3182 slave->phy = in init_secondary_ports()
3184 slave->phy_node, in init_secondary_ports()
3187 if (!slave->phy) { in init_secondary_ports()
3188 dev_err(dev, "phy not found for slave %d\n", in init_secondary_ports()
3189 slave->slave_num); in init_secondary_ports()
3192 phydev_name(slave->phy)); in init_secondary_ports()
3193 phy_start(slave->phy); in init_secondary_ports()
3200 struct gbe_slave *slave; in free_secondary_ports() local
3203 slave = first_sec_slave(gbe_dev); in free_secondary_ports()
3205 if (slave->phy) in free_secondary_ports()
3206 phy_disconnect(slave->phy); in free_secondary_ports()
3207 list_del(&slave->slave_list); in free_secondary_ports()
3649 ret = of_property_read_u32(interface, "slave-port", &slave_num); in gbe_probe()
3651 dev_err(dev, "missing slave-port parameter, skipping interface configuration for %pOFn\n", in gbe_probe()
3666 /* Initialize Secondary slave ports */ in gbe_probe()
3667 secondary_ports = of_get_child_by_name(node, "secondary-slave-ports"); in gbe_probe()
3757 gbe_intf->slave = devm_kzalloc(gbe_dev->dev, in gbe_attach()
3758 sizeof(*gbe_intf->slave), in gbe_attach()
3760 if (!gbe_intf->slave) { in gbe_attach()
3765 if (init_slave(gbe_dev, gbe_intf->slave, node)) { in gbe_attach()
3777 if (gbe_intf->slave) in gbe_attach()
3778 devm_kfree(gbe_dev->dev, gbe_intf->slave); in gbe_attach()
3790 devm_kfree(gbe_intf->dev, gbe_intf->slave); in gbe_release()