On Tuesday 09 May 2006 18:06, Alexey Dobriyan wrote: > > +/* Simplified asprintf. */ > > +char *kasprintf(const char *fmt, ...) > > +{ > > + va_list ap; > > + unsigned int len; > > + char *p, dummy[1]; > > + > > + va_start(ap, fmt); > > + /* FIXME: vsnprintf has a bug, NULL should work */ > > + len = vsnprintf(dummy, 0, fmt, ap); > > + va_end(ap); > > + > > + p = kmalloc(len + 1, GFP_KERNEL); > > + if (!p) > > + return NULL; > > + va_start(ap, fmt); > > + vsprintf(p, fmt, ap); > > + va_end(ap); > > + return p; > > +} > > This should go to lib/ First for kernel usage I think it should have a maximum length parameter to avoid dumb code from being easily exploited. And the bug should be fixed in vsnprintf instead of being worked around. -Andi