Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 83cf79a2 authored by Julian Wiedmann's avatar Julian Wiedmann Committed by David S. Miller
Browse files

s390/qeth: fix early exit from error path



When the allocation of the addr buffer fails, we need to free
our refcount on the inetdevice before returning.

Signed-off-by: default avatarJulian Wiedmann <jwi@linux.vnet.ibm.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 025d0dfc
Loading
Loading
Loading
Loading
+4 −2
Original line number Diff line number Diff line
@@ -1553,7 +1553,7 @@ static void qeth_l3_free_vlan_addresses4(struct qeth_card *card,

	addr = qeth_l3_get_addr_buffer(QETH_PROT_IPV4);
	if (!addr)
		return;
		goto out;

	spin_lock_bh(&card->ip_lock);

@@ -1567,6 +1567,7 @@ static void qeth_l3_free_vlan_addresses4(struct qeth_card *card,
	spin_unlock_bh(&card->ip_lock);

	kfree(addr);
out:
	in_dev_put(in_dev);
}

@@ -1591,7 +1592,7 @@ static void qeth_l3_free_vlan_addresses6(struct qeth_card *card,

	addr = qeth_l3_get_addr_buffer(QETH_PROT_IPV6);
	if (!addr)
		return;
		goto out;

	spin_lock_bh(&card->ip_lock);

@@ -1606,6 +1607,7 @@ static void qeth_l3_free_vlan_addresses6(struct qeth_card *card,
	spin_unlock_bh(&card->ip_lock);

	kfree(addr);
out:
	in6_dev_put(in6_dev);
#endif /* CONFIG_QETH_IPV6 */
}