Skip to content

Commit b91ce4d

Browse files
committed
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6: ipv6: Fix inet6_csk_bind_conflict() e100: Fix the TX workqueue race
2 parents 202f2bb + 6443bb1 commit b91ce4d

File tree

2 files changed

+9
-3
lines changed

2 files changed

+9
-3
lines changed

drivers/net/e100.c

Lines changed: 8 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -166,6 +166,7 @@
166166
#include <linux/ethtool.h>
167167
#include <linux/string.h>
168168
#include <linux/firmware.h>
169+
#include <linux/rtnetlink.h>
169170
#include <asm/unaligned.h>
170171

171172

@@ -2265,8 +2266,13 @@ static void e100_tx_timeout_task(struct work_struct *work)
22652266

22662267
DPRINTK(TX_ERR, DEBUG, "scb.status=0x%02X\n",
22672268
ioread8(&nic->csr->scb.status));
2268-
e100_down(netdev_priv(netdev));
2269-
e100_up(netdev_priv(netdev));
2269+
2270+
rtnl_lock();
2271+
if (netif_running(netdev)) {
2272+
e100_down(netdev_priv(netdev));
2273+
e100_up(netdev_priv(netdev));
2274+
}
2275+
rtnl_unlock();
22702276
}
22712277

22722278
static int e100_loopback_test(struct nic *nic, enum loopback loopback_mode)

net/ipv6/inet6_connection_sock.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -48,7 +48,7 @@ int inet6_csk_bind_conflict(const struct sock *sk,
4848
ipv6_rcv_saddr_equal(sk, sk2))
4949
break;
5050
else if (sk->sk_reuse && sk2->sk_reuse &&
51-
!ipv6_addr_any(inet6_rcv_saddr(sk2)) &&
51+
!ipv6_addr_any(inet6_rcv_saddr(sk)) &&
5252
ipv6_rcv_saddr_equal(sk, sk2))
5353
break;
5454
}

0 commit comments

Comments
 (0)