Re: [RFC] solution for the inet_ntoa problem, buffer allocator

From: Oliver Xymoron (oxymoron@waste.org)
Date: Wed Jul 05 2000 - 11:40:32 EST


On Thu, 6 Jul 2000, Andrew Morton wrote:

> > printk(KERN_DEBUG "foo: src=%a dst=%a\n", src, dst);
>
> Problem with this is that `gcc -Wall' will generate a warning when it
> checks the format string.

Ahh, forgot about that..
 
> I proposed a little hack which avoided that a while back, but it got
> loudly ignored at.
>
> #define FMT_IP4 "\001%ld"
>
> printk(KERN_DEBUG "foo: src=" FMT_IP4 " dst= " FMT_IP4 "\n", src, dst);

Yuck! If we're gonna be hackish, we can use the # flag on d or something:

   printk(KERN_DEBUG "foo: src=%#d dst=%#d\n", &src, &dst);

Though gcc apparently thinks this is a warnable offense as well. #$#$.

If you were going to do something like the ctrl-a hack, I'd propose using
an easily-typed control character as an alternate '%':

   printk(KERN_DEBUG "foo: src=\vi dst=\vi \n", src, dst);

\v is ASCII 11, not used for much of anything and hopefully not appearing
in any existing format strings. You now have a whole alphabet of new
format characters.

Of course, this undoes the benefit of the format checking, but when
compared to hacks like putting dynamic allocation in in_ntoa..

--
 "Love the dolphins," she advised him. "Write by W.A.S.T.E.." 

- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.rutgers.edu Please read the FAQ at http://www.tux.org/lkml/



This archive was generated by hypermail 2b29 : Fri Jul 07 2000 - 21:00:16 EST