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

Commit 8707bdd4 authored by Jarek Poplawski's avatar Jarek Poplawski Committed by David S. Miller
Browse files

gianfar: Fix boot hangs while bringing up gianfar ethernet



Ira Snyder found that commit 8c7396ae
"gianfar: Merge Tx and Rx interrupt for scheduling clean up ring" can
cause hangs. It's because there was removed clearing of interrupts in
gfar_schedule_cleanup() (which is called by an interrupt handler) in
case when netif scheduling has been disabled. This patch brings back
this action and a comment.

Reported-by: default avatarIra Snyder <iws@ovro.caltech.edu>
Reported-by: default avatarPeter Korsgaard <jacmet@sunsite.dk>
Bisected-by: default avatarIra Snyder <iws@ovro.caltech.edu>
Tested-by: default avatarPeter Korsgaard <jacmet@sunsite.dk>
Tested-by: default avatarIra Snyder <iws@ovro.caltech.edu>
Signed-off-by: default avatarJarek Poplawski <jarkao2@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent d4e2675a
Loading
Loading
Loading
Loading
+6 −0
Original line number Diff line number Diff line
@@ -1629,6 +1629,12 @@ static void gfar_schedule_cleanup(struct net_device *dev)
	if (netif_rx_schedule_prep(&priv->napi)) {
		gfar_write(&priv->regs->imask, IMASK_RTX_DISABLED);
		__netif_rx_schedule(&priv->napi);
	} else {
		/*
		 * Clear IEVENT, so interrupts aren't called again
		 * because of the packets that have already arrived.
		 */
		gfar_write(&priv->regs->ievent, IEVENT_RTX_MASK);
	}

	spin_unlock(&priv->rxlock);