Re: [PATCH v2 2/4] printk/kdb: Handle more message headers

From: Petr Mladek
Date: Fri Nov 11 2016 - 13:14:50 EST


On Fri 2016-11-11 12:35:13, Steven Rostedt wrote:
> On Wed, 9 Nov 2016 13:41:29 +0100
> Petr Mladek <pmladek@xxxxxxxx> wrote:
>
> > diff --git a/include/linux/printk.h b/include/linux/printk.h
> > index eac1af8502bb..a0859e169bc3 100644
> > --- a/include/linux/printk.h
> > +++ b/include/linux/printk.h
> > @@ -31,6 +31,14 @@ static inline const char *printk_skip_level(const char *buffer)
> > return buffer;
> > }
> >
> > +static inline const char *printk_skip_headers(const char *buffer)
> > +{
> > + while (printk_get_level(buffer))
> > + buffer = printk_skip_level(buffer);
>
> Hmm, shouldn't there be a length passed in here. What happens if buffer
> ends with a header. Can't this overflow?

It is OK when the string has the trailing '\0'. This is the case here.

Note that printk_skip_level() and printk_get_level() would have the
same problem if only the first byte of the header fit the buffer.

Best Regards,
Petr