Lines Matching refs:slave

129 	if (port->slave == NULL)  in __get_bond_by_port()
132 return bond_get_bond_by_slave(port->slave); in __get_bond_by_port()
146 struct slave *first_slave; in __get_first_agg()
182 bond_set_slave_tx_disabled_flags(port->slave, BOND_SLAVE_NOTIFY_LATER); in __disable_distributing_port()
194 struct slave *slave = port->slave; in __enable_collecting_port() local
196 if (slave->link == BOND_LINK_UP && bond_slave_is_up(slave)) in __enable_collecting_port()
197 bond_set_slave_rx_enabled_flags(slave, BOND_SLAVE_NOTIFY_LATER); in __enable_collecting_port()
208 bond_set_slave_inactive_flags(port->slave, BOND_SLAVE_NOTIFY_LATER); in __disable_port()
219 struct slave *slave = port->slave; in __enable_port() local
221 if ((slave->link == BOND_LINK_UP) && bond_slave_is_up(slave)) in __enable_port()
222 bond_set_slave_active_flags(slave, BOND_SLAVE_NOTIFY_LATER); in __enable_port()
248 return bond_is_active_slave(port->slave); in __port_is_collecting_distributing()
306 struct slave *slave = port->slave; in __get_link_speed() local
314 if (slave->link != BOND_LINK_UP) in __get_link_speed()
317 switch (slave->speed) { in __get_link_speed()
384 if (slave->speed != SPEED_UNKNOWN) in __get_link_speed()
386 slave->bond->dev->name, in __get_link_speed()
387 slave->dev->name, slave->speed, in __get_link_speed()
394 slave_dbg(slave->bond->dev, slave->dev, "Port %d Received link speed %d update from adapter\n", in __get_link_speed()
409 struct slave *slave = port->slave; in __get_duplex() local
415 if (slave->link == BOND_LINK_UP) { in __get_duplex()
416 switch (slave->duplex) { in __get_duplex()
419 …slave_dbg(slave->bond->dev, slave->dev, "Port %d Received status full duplex update from adapter\n… in __get_duplex()
425 …slave_dbg(slave->bond->dev, slave->dev, "Port %d Received status NOT full duplex update from adapt… in __get_duplex()
435 const struct bonding *bond = bond_get_bond_by_slave(port->slave); in __ad_actor_update_port()
560 slave_dbg(port->slave->bond->dev, port->slave->dev, in __record_pdu()
564 slave_dbg(port->slave->bond->dev, port->slave->dev, in __record_pdu()
827 struct bonding *bond = aggregator->slave->bond; in __get_active_agg()
829 struct slave *slave; in __get_active_agg() local
831 bond_for_each_slave_rcu(bond, slave, iter) in __get_active_agg()
832 if (SLAVE_AD_INFO(slave)->aggregator.is_active) in __get_active_agg()
833 return &(SLAVE_AD_INFO(slave)->aggregator); in __get_active_agg()
860 slave_dbg(port->slave->bond->dev, port->slave->dev, in __update_lacpdu_from_port()
898 struct slave *slave = port->slave; in ad_lacpdu_send() local
907 atomic64_inc(&SLAVE_AD_INFO(slave)->stats.lacpdu_tx); in ad_lacpdu_send()
908 atomic64_inc(&BOND_AD_INFO(slave->bond).stats.lacpdu_tx); in ad_lacpdu_send()
910 skb->dev = slave->dev; in ad_lacpdu_send()
922 ether_addr_copy(lacpdu_header->hdr.h_source, slave->perm_hwaddr); in ad_lacpdu_send()
942 struct slave *slave = port->slave; in ad_marker_send() local
953 atomic64_inc(&SLAVE_AD_INFO(slave)->stats.marker_tx); in ad_marker_send()
954 atomic64_inc(&BOND_AD_INFO(slave->bond).stats.marker_tx); in ad_marker_send()
957 atomic64_inc(&SLAVE_AD_INFO(slave)->stats.marker_resp_tx); in ad_marker_send()
958 atomic64_inc(&BOND_AD_INFO(slave->bond).stats.marker_resp_tx); in ad_marker_send()
964 skb->dev = slave->dev; in ad_marker_send()
975 ether_addr_copy(marker_header->hdr.h_source, slave->perm_hwaddr); in ad_marker_send()
987 struct bonding *bond = port->slave->bond; in ad_cond_set_peer_notif()
1107 struct slave *slave = port->slave; in ad_mux_machine() local
1110 bond_is_slave_rx_disabled(slave)) { in ad_mux_machine()
1144 slave_dbg(port->slave->bond->dev, port->slave->dev, in ad_mux_machine()
1221 atomic64_inc(&SLAVE_AD_INFO(port->slave)->stats.lacpdu_rx); in ad_rx_machine()
1222 atomic64_inc(&BOND_AD_INFO(port->slave->bond).stats.lacpdu_rx); in ad_rx_machine()
1276 slave_dbg(port->slave->bond->dev, port->slave->dev, in ad_rx_machine()
1328 slave_err(port->slave->bond->dev, port->slave->dev, "An illegal loopback occurred on slave\n" in ad_rx_machine()
1398 slave_dbg(port->slave->bond->dev, in ad_tx_machine()
1399 port->slave->dev, in ad_tx_machine()
1482 slave_dbg(port->slave->bond->dev, port->slave->dev, in ad_periodic_machine()
1522 struct slave *slave; in ad_port_selection_logic() local
1561 slave_dbg(bond->dev, port->slave->dev, "Port %d left LAG %d\n", in ad_port_selection_logic()
1577 port->slave->bond->dev->name, in ad_port_selection_logic()
1578 port->slave->dev->name, in ad_port_selection_logic()
1584 bond_for_each_slave(bond, slave, iter) { in ad_port_selection_logic()
1585 aggregator = &(SLAVE_AD_INFO(slave)->aggregator); in ad_port_selection_logic()
1610 slave_dbg(bond->dev, slave->dev, "Port %d joined LAG %d (existing LAG)\n", in ad_port_selection_logic()
1657 slave_dbg(bond->dev, port->slave->dev, "Port %d joined LAG %d (new LAG)\n", in ad_port_selection_logic()
1661 slave_err(bond->dev, port->slave->dev, in ad_port_selection_logic()
1744 curr->slave->bond->dev->name, in ad_agg_selection_test()
1745 curr->slave->dev->name, in ad_agg_selection_test()
1762 if (netif_running(port->slave->dev) && in agg_device_up()
1763 netif_carrier_ok(port->slave->dev)) in agg_device_up()
1800 struct bonding *bond = agg->slave->bond; in ad_agg_selection_logic()
1802 struct slave *slave; in ad_agg_selection_logic() local
1810 bond_for_each_slave_rcu(bond, slave, iter) { in ad_agg_selection_logic()
1811 agg = &(SLAVE_AD_INFO(slave)->aggregator); in ad_agg_selection_logic()
1847 best->slave ? best->slave->dev->name : "NULL", in ad_agg_selection_logic()
1853 best->slave ? best->slave->dev->name : "NULL", in ad_agg_selection_logic()
1854 best->lag_ports, best->slave); in ad_agg_selection_logic()
1856 bond_for_each_slave_rcu(bond, slave, iter) { in ad_agg_selection_logic()
1857 agg = &(SLAVE_AD_INFO(slave)->aggregator); in ad_agg_selection_logic()
1859 slave_dbg(bond->dev, slave->dev, "Agg=%d; P=%d; a k=%d; p k=%d; Ind=%d; Act=%d\n", in ad_agg_selection_logic()
1873 best->slave ? best->slave->dev->name : "NULL", in ad_agg_selection_logic()
1876 best->slave ? best->slave->dev->name : "NULL", in ad_agg_selection_logic()
1934 aggregator->slave ? in ad_clear_agg()
1935 aggregator->slave->dev->name : "NULL", in ad_clear_agg()
1951 aggregator->slave = NULL; in ad_initialize_agg()
2030 struct slave *slave = port->slave; in ad_enable_collecting() local
2032 slave_dbg(slave->bond->dev, slave->dev, in ad_enable_collecting()
2048 slave_dbg(port->slave->bond->dev, port->slave->dev, in ad_disable_distributing()
2069 slave_dbg(port->slave->bond->dev, port->slave->dev, in ad_enable_collecting_distributing()
2090 slave_dbg(port->slave->bond->dev, port->slave->dev, in ad_disable_collecting_distributing()
2110 atomic64_inc(&SLAVE_AD_INFO(port->slave)->stats.marker_rx); in ad_marker_info_received()
2111 atomic64_inc(&BOND_AD_INFO(port->slave->bond).stats.marker_rx); in ad_marker_info_received()
2120 slave_dbg(port->slave->bond->dev, port->slave->dev, in ad_marker_info_received()
2137 atomic64_inc(&SLAVE_AD_INFO(port->slave)->stats.marker_resp_rx); in ad_marker_response_received()
2138 atomic64_inc(&BOND_AD_INFO(port->slave->bond).stats.marker_resp_rx); in ad_marker_response_received()
2192 void bond_3ad_bind_slave(struct slave *slave) in bond_3ad_bind_slave() argument
2194 struct bonding *bond = bond_get_bond_by_slave(slave); in bond_3ad_bind_slave()
2199 if (SLAVE_AD_INFO(slave)->port.slave != slave) { in bond_3ad_bind_slave()
2202 port = &(SLAVE_AD_INFO(slave)->port); in bond_3ad_bind_slave()
2206 port->slave = slave; in bond_3ad_bind_slave()
2207 port->actor_port_number = SLAVE_AD_INFO(slave)->id; in bond_3ad_bind_slave()
2223 aggregator = &(SLAVE_AD_INFO(slave)->aggregator); in bond_3ad_bind_slave()
2229 aggregator->slave = slave; in bond_3ad_bind_slave()
2243 void bond_3ad_unbind_slave(struct slave *slave) in bond_3ad_unbind_slave() argument
2248 struct bonding *bond = slave->bond; in bond_3ad_unbind_slave()
2249 struct slave *slave_iter; in bond_3ad_unbind_slave()
2255 aggregator = &(SLAVE_AD_INFO(slave)->aggregator); in bond_3ad_unbind_slave()
2256 port = &(SLAVE_AD_INFO(slave)->port); in bond_3ad_unbind_slave()
2259 if (!port->slave) { in bond_3ad_unbind_slave()
2260 slave_warn(bond->dev, slave->dev, "Trying to unbind an uninitialized port\n"); in bond_3ad_unbind_slave()
2264 slave_dbg(bond->dev, slave->dev, "Unbinding Link Aggregation Group %d\n", in bond_3ad_unbind_slave()
2303 slave_dbg(bond->dev, slave->dev, "Some port(s) related to LAG %d - replacing with LAG %d\n", in bond_3ad_unbind_slave()
2309 slave_info(bond->dev, slave->dev, "Removing an active aggregator\n"); in bond_3ad_unbind_slave()
2340 …slave_warn(bond->dev, slave->dev, "unbinding aggregator, and could not find a new aggregator for i… in bond_3ad_unbind_slave()
2349 slave_info(bond->dev, slave->dev, "Removing an active aggregator\n"); in bond_3ad_unbind_slave()
2359 slave_dbg(bond->dev, slave->dev, "Unbinding port %d\n", port->actor_port_number); in bond_3ad_unbind_slave()
2383 slave_info(bond->dev, slave->dev, "Removing an active aggregator\n"); in bond_3ad_unbind_slave()
2393 port->slave = NULL; in bond_3ad_unbind_slave()
2409 struct slave *slave; in bond_3ad_update_ad_actor_settings() local
2422 bond_for_each_slave(bond, slave, iter) { in bond_3ad_update_ad_actor_settings()
2423 struct port *port = &(SLAVE_AD_INFO(slave))->port; in bond_3ad_update_ad_actor_settings()
2472 struct slave *slave; in bond_3ad_state_machine_handler() local
2489 slave = bond_first_slave_rcu(bond); in bond_3ad_state_machine_handler()
2490 port = slave ? &(SLAVE_AD_INFO(slave)->port) : NULL; in bond_3ad_state_machine_handler()
2494 if (!port->slave) { in bond_3ad_state_machine_handler()
2507 bond_for_each_slave_rcu(bond, slave, iter) { in bond_3ad_state_machine_handler()
2508 port = &(SLAVE_AD_INFO(slave)->port); in bond_3ad_state_machine_handler()
2509 if (!port->slave) { in bond_3ad_state_machine_handler()
2528 bond_for_each_slave_rcu(bond, slave, iter) { in bond_3ad_state_machine_handler()
2529 if (slave->should_notify) { in bond_3ad_state_machine_handler()
2556 static int bond_3ad_rx_indication(struct lacpdu *lacpdu, struct slave *slave) in bond_3ad_rx_indication() argument
2558 struct bonding *bond = slave->bond; in bond_3ad_rx_indication()
2564 port = &(SLAVE_AD_INFO(slave)->port); in bond_3ad_rx_indication()
2565 if (!port->slave) { in bond_3ad_rx_indication()
2567 slave->dev->name, slave->bond->dev->name); in bond_3ad_rx_indication()
2574 slave_dbg(slave->bond->dev, slave->dev, in bond_3ad_rx_indication()
2578 spin_lock(&slave->bond->mode_lock); in bond_3ad_rx_indication()
2580 spin_unlock(&slave->bond->mode_lock); in bond_3ad_rx_indication()
2590 slave_dbg(slave->bond->dev, slave->dev, "Received Marker Information on port %d\n", in bond_3ad_rx_indication()
2595 slave_dbg(slave->bond->dev, slave->dev, "Received Marker Response on port %d\n", in bond_3ad_rx_indication()
2600 slave_dbg(slave->bond->dev, slave->dev, "Received an unknown Marker subtype on port %d\n", in bond_3ad_rx_indication()
2602 stat = &SLAVE_AD_INFO(slave)->stats.marker_unknown_rx; in bond_3ad_rx_indication()
2609 atomic64_inc(&SLAVE_AD_INFO(slave)->stats.lacpdu_unknown_rx); in bond_3ad_rx_indication()
2651 slave_err(port->slave->bond->dev, in ad_update_actor_keys()
2652 port->slave->dev, in ad_update_actor_keys()
2671 void bond_3ad_adapter_speed_duplex_changed(struct slave *slave) in bond_3ad_adapter_speed_duplex_changed() argument
2675 port = &(SLAVE_AD_INFO(slave)->port); in bond_3ad_adapter_speed_duplex_changed()
2678 if (!port->slave) { in bond_3ad_adapter_speed_duplex_changed()
2679 slave_warn(slave->bond->dev, slave->dev, in bond_3ad_adapter_speed_duplex_changed()
2684 spin_lock_bh(&slave->bond->mode_lock); in bond_3ad_adapter_speed_duplex_changed()
2686 spin_unlock_bh(&slave->bond->mode_lock); in bond_3ad_adapter_speed_duplex_changed()
2687 slave_dbg(slave->bond->dev, slave->dev, "Port %d changed speed/duplex\n", in bond_3ad_adapter_speed_duplex_changed()
2698 void bond_3ad_handle_link_change(struct slave *slave, char link) in bond_3ad_handle_link_change() argument
2704 port = &(SLAVE_AD_INFO(slave)->port); in bond_3ad_handle_link_change()
2707 if (!port->slave) { in bond_3ad_handle_link_change()
2708 slave_warn(slave->bond->dev, slave->dev, "link status changed for uninitialized port\n"); in bond_3ad_handle_link_change()
2712 spin_lock_bh(&slave->bond->mode_lock); in bond_3ad_handle_link_change()
2731 spin_unlock_bh(&slave->bond->mode_lock); in bond_3ad_handle_link_change()
2733 slave_dbg(slave->bond->dev, slave->dev, "Port %d changed link status to %s\n", in bond_3ad_handle_link_change()
2740 bond_update_slave_arr(slave->bond, NULL); in bond_3ad_handle_link_change()
2759 struct slave *first_slave; in bond_3ad_set_carrier()
2801 struct slave *slave; in __bond_3ad_get_active_agg_info() local
2804 bond_for_each_slave_rcu(bond, slave, iter) { in __bond_3ad_get_active_agg_info()
2805 port = &(SLAVE_AD_INFO(slave)->port); in __bond_3ad_get_active_agg_info()
2836 struct slave *slave) in bond_3ad_lacpdu_recv() argument
2848 atomic64_inc(&SLAVE_AD_INFO(slave)->stats.lacpdu_illegal_rx); in bond_3ad_lacpdu_recv()
2853 return bond_3ad_rx_indication(lacpdu, slave); in bond_3ad_lacpdu_recv()
2871 struct slave *slave; in bond_3ad_update_lacp_rate() local
2876 bond_for_each_slave(bond, slave, iter) { in bond_3ad_update_lacp_rate()
2877 port = &(SLAVE_AD_INFO(slave)->port); in bond_3ad_update_lacp_rate()