From 41aecabcf6c08195c5f2cd16d2b4faed1eb7dbcd Mon Sep 17 00:00:00 2001 From: Neil Horman Date: Wed, 13 Oct 2010 16:01:51 +0000 Subject: [PATCH] --- yaml --- r: 215226 b: refs/heads/master c: 990c3d6f9c4115347659fc2b163907c8c832ae44 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/net/core/netpoll.c | 9 ++++++++- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/[refs] b/[refs] index 91555e8089ea..20fe21defa5e 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: e843fa50887582c867d8b7995f81fe9c1a076806 +refs/heads/master: 990c3d6f9c4115347659fc2b163907c8c832ae44 diff --git a/trunk/net/core/netpoll.c b/trunk/net/core/netpoll.c index 4e98ffac3af0..d79d221fd1f4 100644 --- a/trunk/net/core/netpoll.c +++ b/trunk/net/core/netpoll.c @@ -156,8 +156,15 @@ static void poll_napi(struct net_device *dev) { struct napi_struct *napi; int budget = 16; + struct softnet_data *sd = &__get_cpu_var(softnet_data); + struct list_head *nlist; - list_for_each_entry(napi, &dev->napi_list, dev_list) { + if (dev->flags & IFF_MASTER) + nlist = &sd->poll_list; + else + nlist = &dev->napi_list; + + list_for_each_entry(napi, nlist, dev_list) { if (napi->poll_owner != smp_processor_id() && spin_trylock(&napi->poll_lock)) { budget = poll_one_napi(dev->npinfo, napi, budget);