Re: [RFC][PATCH 1/3] trace_seq: Move the trace_seq code to lib/

From: Steven Rostedt
Date: Mon Jun 23 2014 - 14:04:21 EST


On Mon, 23 Jun 2014 19:38:14 +0200
Johannes Berg <johannes@xxxxxxxxxxxxxxxx> wrote:

> On Mon, 2014-06-23 at 12:08 -0400, Steven Rostedt wrote:
> > On Sun, 22 Jun 2014 09:38:05 +0200
> > Johannes Berg <johannes@xxxxxxxxxxxxxxxx> wrote:
> >
> >
> > > Looking at the code though, I'm not sure it's a pure optimisation - if
> > > you do say putc() after a failed puts(), without this code the putc()
> > > would succeed? I can't tell right now if that's really a problem, but it
> > > seems you could get some odd behaviour out of it.
> >
> > How would putc() still succeed? We're just talking about the "full"
> > field. It would still do the length check:
> >
> > if (s->len >= (PAGE_SIZE - 1))
> > return 0;
>
> Right, but the puts() could fail if not all of the string fits, and a
> subsequent putc() might fit.
>

Ah! I see what you are saying. You are saying that once you are full
you need to flush. Honestly, the trace_puts() should check the return.
Perhaps it wants to try again with a shorter string?

The full flag means that once we hit full, we are done, no more can be
written till the buffer is flushed.

Is that what we would want from this utility? Or do we want to allow
the user to try again with a smaller string?

I was thinking of reversing the error code and have the trace_seq_*()
return 0 as success and the remaining buffer size on error.

-- Steve
--
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/