mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-16 16:26:57 +07:00
s390/qeth: fine-tune RX modesetting
Changing a device's address lists (or its promisc mode) already triggers an RX modeset, there's no need to do it manually from the L2 driver's ndo_vlan_rx_kill_vid() hook. Also when setting a device online, dev_open() already calls dev_set_rx_mode(). So a manual modeset is only necessary from the recovery path. Signed-off-by: Julian Wiedmann <jwi@linux.ibm.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f67a43a73b
commit
9aa17df3b8
@ -26,7 +26,6 @@
|
|||||||
|
|
||||||
static int qeth_l2_set_offline(struct ccwgroup_device *);
|
static int qeth_l2_set_offline(struct ccwgroup_device *);
|
||||||
static int qeth_l2_stop(struct net_device *);
|
static int qeth_l2_stop(struct net_device *);
|
||||||
static void qeth_l2_set_rx_mode(struct net_device *);
|
|
||||||
static void qeth_bridgeport_query_support(struct qeth_card *card);
|
static void qeth_bridgeport_query_support(struct qeth_card *card);
|
||||||
static void qeth_bridge_state_change(struct qeth_card *card,
|
static void qeth_bridge_state_change(struct qeth_card *card,
|
||||||
struct qeth_ipa_cmd *cmd);
|
struct qeth_ipa_cmd *cmd);
|
||||||
@ -344,7 +343,6 @@ static int qeth_l2_vlan_rx_kill_vid(struct net_device *dev,
|
|||||||
rc = qeth_l2_send_setdelvlan(card, vid, IPA_CMD_DELVLAN);
|
rc = qeth_l2_send_setdelvlan(card, vid, IPA_CMD_DELVLAN);
|
||||||
kfree(tmpid);
|
kfree(tmpid);
|
||||||
}
|
}
|
||||||
qeth_l2_set_rx_mode(card->dev);
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1125,13 +1123,12 @@ static int __qeth_l2_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||||||
if (recovery_mode &&
|
if (recovery_mode &&
|
||||||
card->info.type != QETH_CARD_TYPE_OSN) {
|
card->info.type != QETH_CARD_TYPE_OSN) {
|
||||||
__qeth_l2_open(card->dev);
|
__qeth_l2_open(card->dev);
|
||||||
|
qeth_l2_set_rx_mode(card->dev);
|
||||||
} else {
|
} else {
|
||||||
rtnl_lock();
|
rtnl_lock();
|
||||||
dev_open(card->dev);
|
dev_open(card->dev);
|
||||||
rtnl_unlock();
|
rtnl_unlock();
|
||||||
}
|
}
|
||||||
/* this also sets saved unicast addresses */
|
|
||||||
qeth_l2_set_rx_mode(card->dev);
|
|
||||||
}
|
}
|
||||||
/* let user_space know that device is online */
|
/* let user_space know that device is online */
|
||||||
kobject_uevent(&gdev->dev.kobj, KOBJ_CHANGE);
|
kobject_uevent(&gdev->dev.kobj, KOBJ_CHANGE);
|
||||||
|
@ -2666,11 +2666,12 @@ static int __qeth_l3_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||||||
qeth_enable_hw_features(card->dev);
|
qeth_enable_hw_features(card->dev);
|
||||||
if (recover_flag == CARD_STATE_RECOVER) {
|
if (recover_flag == CARD_STATE_RECOVER) {
|
||||||
rtnl_lock();
|
rtnl_lock();
|
||||||
if (recovery_mode)
|
if (recovery_mode) {
|
||||||
__qeth_l3_open(card->dev);
|
__qeth_l3_open(card->dev);
|
||||||
else
|
qeth_l3_set_rx_mode(card->dev);
|
||||||
|
} else {
|
||||||
dev_open(card->dev);
|
dev_open(card->dev);
|
||||||
qeth_l3_set_rx_mode(card->dev);
|
}
|
||||||
rtnl_unlock();
|
rtnl_unlock();
|
||||||
}
|
}
|
||||||
qeth_trace_features(card);
|
qeth_trace_features(card);
|
||||||
|
Loading…
Reference in New Issue
Block a user