[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20090622121853.GC6994@ff.dom.local>
Date: Mon, 22 Jun 2009 12:18:53 +0000
From: Jarek Poplawski <jarkao2@...il.com>
To: Neil Horman <nhorman@...driver.com>
Cc: Alexey Kuznetsov <kuznet@....inr.ac.ru>,
David Miller <davem@...emloft.net>, netdev@...r.kernel.org,
mbizon@...ebox.fr, dada1@...mosbay.com, pekkas@...core.fi,
jmorris@...ei.org, yoshfuji@...ux-ipv6.org
Subject: Re: [PATCH] fix NULL pointer + success return in route lookup path
On Mon, Jun 22, 2009 at 07:08:19AM -0400, Neil Horman wrote:
> On Mon, Jun 22, 2009 at 11:00:23AM +0000, Jarek Poplawski wrote:
> > On Mon, Jun 22, 2009 at 12:59:50PM +0400, Alexey Kuznetsov wrote:
> > > On Mon, Jun 22, 2009 at 05:43:15AM +0000, Jarek Poplawski wrote:
> > > > Maybe it can work, but it needs a thorough checking now and adds a new
> > > > code path to track later while looking for bugs. So, I wonder if it's
> > > > not better to link such dsts in rt_intern_hash anyway, probably as a
> > > > separate list, scanned only for expired entries.
> > >
> > > Such a list already exists, it is gc list in core/dst.c.
> > >
> > > The fix to the problem could be replacing rt_drop() with rt_free()
> > > (adding rt_free() after the patch, which deleted rt_drop()), something like:
> > >
> > > if (!rt_caching(dev_net(rt->u.dst.dev))) {
> > > /* ..... */
> > > + rt_free(rt);
> > > goto report_and_exit;
> > > }
> > >
> > > rt_free() will put the route on that gc list and it will be releases
> > > as soon as refcnt becomes 0.
> >
> > One little doubt would be RCU: if it's currently used in rt_free, and
> > some code depends on it, there would be a change: rt could be freed
> > just after atomic dec, without waiting for RCU yet. The second one is
>
> Not sure that I see the concern. How are we going to call dst_rcu_free without
> waiting for a quiesence of the use of this route? When it enters rt_intern_hash
> is use count is one, and if we call rt_free in this case, we are guaranteeing
> that this path is the only user (no one else will be able to get a reference to
> it as they can't look it up in the cache). Once the route is dropped at the end
> of this route lookup, its use is over and the garbage collector will reap it.
The main question is where this RCU is really needed? (I guess not in
route cache, which controls moving it to dst gc.) If it's not necessary
like Alexey wrote, then this change doesn't matter.
>
> > about timing: freeing this always from a workqueue could probably
> > make a problem if softirqs are often disabled.
> >
> You mean often, or permanently? If softirqs are often disabled, thats no big
> deal, as long as they are enabled at least sometimes, the garbage colelctor will
> run, and we'll be ok. If softirqs are disabled permanently (or for sufficiently
> long periods that we gather huge number of routes waiting to be reaped), I think
> we have larger problems on our hands
If there is a lot of new skbs per napi and a workqueue code triggered
later there could be problem with getting this memory back on time.
Jarek P.
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists