]> git.kernelconcepts.de Git - karo-tx-linux.git/commit
sungem: Soft lockup in sungem on Netra AC200 when switching interface up
authorIlkka Virta <itvirta@iki.fi>
Sat, 7 Feb 2009 06:00:36 +0000 (22:00 -0800)
committerGreg Kroah-Hartman <gregkh@suse.de>
Tue, 17 Feb 2009 17:28:56 +0000 (09:28 -0800)
commit8527040ae52a767037fe3faec6aeeed474b48104
tree87e497294d6f0e5e2988c87a5b6709d650cd501b
parentb5934d35aceba7534aca1e37000753d74919d867
sungem: Soft lockup in sungem on Netra AC200 when switching interface up

[ Upstream commit 71822faa3bc0af5dbf5e333a2d085f1ed7cd809f ]

From: Ilkka Virta <itvirta@iki.fi>

In the lockup situation the driver seems to go off in an eternal storm
of interrupts right after calling request_irq(). It doesn't actually
do anything interesting in the interrupt handler. Since connecting the link
afterwards works, something later in initialization must fix this.

Looking at gem_do_start() and gem_open(), it seems that the only thing
done while opening the device after the request_irq(), is a call to
napi_enable().

I don't know what the ordering requirements are for the
initialization, but I boldly tried to move the napi_enable() call
inside gem_do_start() before the link state is checked and interrupts
subsequently enabled, and it seems to work for me. Doesn't even break
anything too obvious...

Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/net/sungem.c