Re: [patch 13/17] Use WARN() in drivers/base/
From: Arjan van de Ven
Date: Fri Jul 11 2008 - 19:56:45 EST
On Fri, 11 Jul 2008 16:02:13 -0700
Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> wrote:
> On Fri, 11 Jul 2008 15:51:05 -0700 Arjan van de Ven
> <arjan@xxxxxxxxxxxxx> wrote:
>
> > On Fri, 11 Jul 2008 15:11:10 -0700
> > Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> wrote:
> >
> > >
> > > I don't suppose there's any way of tricking the preprocessor into
> > > supporting
> > >
> > > WARN_ON(foo == 42);
> > >
> > > as well as
> > >
> > > WARN_ON(foo == 42, "bite me!");
> > >
> >
> > after reading preprocessor docs from gcc and trying some things:
> > We can do this. It comes at a price: the price is a blank line in
> > the WARN trace for the "no printk comments" case, and we lose the
> > ability to override the printk level. (which you can argue is a
> > feature by just setting it to KERN_WARNING).
> >
> > (and some interesting but otherwise non-harmful preprocessor stuff
> > in headers)
>
> the blank line: might be avoidable by doing some extra work at runtime
> to recognise its presence?
probably (but vararg stuff is weird)
>
> overriding facility level: doesn't sound very useful, as WARN()'s
> stack-trace's facility level is not controllable.
ok
>
> > Is this is price worth paying to not have a second macro?
>
> Dunno, how ugly is the patch?
it's not too bad ;) I'll turn the userland experiment into a kernel
patch tomorrow or so
>
> It would be rather nice to not go and fatten the interface. Would
> there be additional text or data size costs?
there will be a few bytes of text in the out of line implementation;
I'm not too worried about that.
There shouldn't be a per-instance overhead
--
If you want to reach me at my work email, use arjan@xxxxxxxxxxxxxxx
For development, discussion and tips for power savings,
visit http://www.lesswatts.org
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/