From: Stephen Hemminger <[EMAIL PROTECTED]>
Date: Wed, 19 Sep 2007 15:01:29 -0700

> There might be a future problem if some driver decided to change
> weight often on the fly?  Perhaps you need to sample it once in
> start of napi_schedule.

Fair enough, I checked the following into net-2.6.24

commit 3b4eed9f46e4b0405a0d8921c2319f2b7c6a6b4a
Author: David S. Miller <[EMAIL PROTECTED]>
Date:   Wed Sep 19 15:09:55 2007 -0700

    [NAPI]: Sample weight into a local var in case it changes.
    
    Noted by Stephen Hemminger.
    
    Signed-off-by: David S. Miller <[EMAIL PROTECTED]>

diff --git a/net/core/dev.c b/net/core/dev.c
index 0b9f82e..91c31e6 100644
--- a/net/core/dev.c
+++ b/net/core/dev.c
@@ -2136,7 +2136,7 @@ static void net_rx_action(struct softirq_action *h)
 
        while (!list_empty(list)) {
                struct napi_struct *n;
-               int work;
+               int work, weight;
 
                /* If softirq window is exhuasted then punt.
                 *
@@ -2159,9 +2159,11 @@ static void net_rx_action(struct softirq_action *h)
 
                have = netpoll_poll_lock(n);
 
-               work = n->poll(n, n->weight);
+               weight = n->weight;
 
-               WARN_ON_ONCE(work > n->weight);
+               work = n->poll(n, weight);
+
+               WARN_ON_ONCE(work > weight);
 
                budget -= work;
 
@@ -2172,7 +2174,7 @@ 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 == n->weight))
+               if (unlikely(work == weight))
                        list_move_tail(&n->poll_list, list);
 
                netpoll_poll_unlock(have);
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to