netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH net-next v1 0/3] forcedeth: fix device lock-up for dual-port NICs
@ 2012-08-25  3:22 David Decotigny
  2012-08-25  3:22 ` [PATCH net-next v1 1/3] forcedeth: fix buffer overflow David Decotigny
                   ` (3 more replies)
  0 siblings, 4 replies; 5+ messages in thread
From: David Decotigny @ 2012-08-25  3:22 UTC (permalink / raw)
  To: Ayaz Abdulla, netdev, linux-kernel
  Cc: David S. Miller, Eric Dumazet, Joe Perches, David Decotigny

On a dual port MCP55 10de:0373 (rev a3) NIC with both ports connected,
we identified a configuration that does freeze the whole NIC: having
autoneg & TX pause turned on while one port is physically connected
but interface is down (eg. eth1) eventually causes the whole NIC to
freeze (eth1 and... eth0). This triggers TX timeouts on the UP
interface and, more generally, an unreachable network.

In order to avoid the bug, all we have to do is make sure not to
configure TX pause on the hardware while NIC is down. This is what the
2nd patch of the series does (details included).

And, in case the NIC is in a bad state at reboot (should not happen
anymore thanks to patch above), third patch basically always makes
sure to fix the NIC when module is loaded.

I could only test this with a MCP55 10de:0373 (rev a3) PCI device on a
x86_64 host.

Any feedback on these patches welcome! In particular, please let me
know if this should not apply to other hardware.


############################################
# Patch Set Summary:

David Decotigny (3):
  forcedeth: fix buffer overflow
  forcedeth: fix TX timeout caused by TX pause on down link
  forcedeth: prevent TX timeouts after reboot

 drivers/net/ethernet/nvidia/forcedeth.c |   16 ++++++++++++----
 1 file changed, 12 insertions(+), 4 deletions(-)

-- 
1.7.10.2.5.g20d7bc9

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2012-08-30 17:05 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-08-25  3:22 [PATCH net-next v1 0/3] forcedeth: fix device lock-up for dual-port NICs David Decotigny
2012-08-25  3:22 ` [PATCH net-next v1 1/3] forcedeth: fix buffer overflow David Decotigny
2012-08-25  3:22 ` [PATCH net-next v1 2/3] forcedeth: fix TX timeout caused by TX pause on down link David Decotigny
2012-08-25  3:22 ` [PATCH net-next v1 3/3] forcedeth: prevent TX timeouts after reboot David Decotigny
2012-08-30 17:05 ` [PATCH net-next v1 0/3] forcedeth: fix device lock-up for dual-port NICs David Miller

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).