Skip to content

Commit 98d823a

Browse files
julianwiedmanndavem330
authored andcommitted
s390/qeth: fix IP removal on offline cards
If the HW is not reachable, then none of the IPs in qeth's internal table has been registered with the HW yet. So when deleting such an IP, there's no need to stage it for deregistration - just drop it from the table. This fixes the "add-delete-add" scenario on an offline card, where the the second "add" merely increments the IP's use count. But as the IP is still set to DISP_ADDR_DELETE from the previous "delete" step, l3_recover_ip() won't register it with the HW when the card goes online. Fixes: 5f78e29 ("qeth: optimize IP handling in rx_mode callback") Signed-off-by: Julian Wiedmann <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 12472af commit 98d823a

File tree

1 file changed

+3
-11
lines changed

1 file changed

+3
-11
lines changed

drivers/s390/net/qeth_l3_main.c

Lines changed: 3 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -173,12 +173,8 @@ int qeth_l3_delete_ip(struct qeth_card *card, struct qeth_ipaddr *tmp_addr)
173173
if (addr->in_progress)
174174
return -EINPROGRESS;
175175

176-
if (!qeth_card_hw_is_reachable(card)) {
177-
addr->disp_flag = QETH_DISP_ADDR_DELETE;
178-
return 0;
179-
}
180-
181-
rc = qeth_l3_deregister_addr_entry(card, addr);
176+
if (qeth_card_hw_is_reachable(card))
177+
rc = qeth_l3_deregister_addr_entry(card, addr);
182178

183179
hash_del(&addr->hnode);
184180
kfree(addr);
@@ -321,11 +317,7 @@ static void qeth_l3_recover_ip(struct qeth_card *card)
321317
spin_lock_bh(&card->ip_lock);
322318

323319
hash_for_each_safe(card->ip_htable, i, tmp, addr, hnode) {
324-
if (addr->disp_flag == QETH_DISP_ADDR_DELETE) {
325-
qeth_l3_deregister_addr_entry(card, addr);
326-
hash_del(&addr->hnode);
327-
kfree(addr);
328-
} else if (addr->disp_flag == QETH_DISP_ADDR_ADD) {
320+
if (addr->disp_flag == QETH_DISP_ADDR_ADD) {
329321
if (addr->proto == QETH_PROT_IPV4) {
330322
addr->in_progress = 1;
331323
spin_unlock_bh(&card->ip_lock);

0 commit comments

Comments
 (0)