From: David S. Miller Date: Tue, 8 Jan 2008 05:00:40 +0000 (-0800) Subject: [NET]: Stop polling when napi_disable() is pending. X-Git-Tag: v2.6.24-rc8~54^2~13 X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=fed17f3094b960d3a54b10f17abbe4b57e976eec;p=linux-2.6 [NET]: Stop polling when napi_disable() is pending. This finally adds the code in net_rx_action() to break out of the ->poll()'ing loop when a napi_disable() is found to be pending. Now, even if a device is being flooded with packets it can be cleanly brought down. Signed-off-by: David S. Miller --- diff --git a/net/core/dev.c b/net/core/dev.c index be9d3015be..0879f52115 100644 --- a/net/core/dev.c +++ b/net/core/dev.c @@ -2207,8 +2207,12 @@ static void net_rx_action(struct softirq_action *h) * still "owns" the NAPI instance and therefore can * move the instance around on the list at-will. */ - if (unlikely(work == weight)) - list_move_tail(&n->poll_list, list); + if (unlikely(work == weight)) { + if (unlikely(napi_disable_pending(n))) + __napi_complete(n); + else + list_move_tail(&n->poll_list, list); + } netpoll_poll_unlock(have); }