Re: [PATCH v13 04/14] perf, tools: Allow events with dot
From: Robert Richter
Date: Tue Jun 16 2015 - 05:29:29 EST
On 03.06.15 12:32:04, Jiri Olsa wrote:
> On Tue, Jun 02, 2015 at 10:12:04AM -0700, Sukadev Bhattiprolu wrote:
> > From: Andi Kleen <ak@xxxxxxxxxxxxxxx>
> >
> > The Intel events use a dot to separate event name and unit mask.
> > Allow dot in names in the scanner, and remove special handling
> > of dot as EOF. Also remove the hack in jevents to replace dot
> > with underscore. This way dotted events can be specified
> > directly by the user.
> >
> > I'm not fully sure this change to the scanner is correct
> > (what was the dot special case good for?), but I haven't
> > found anything that breaks with it so far at least.
>
> can't see anything either
>
> Robert,
> does it ring a bell? seems like you introduced it ;-)
It is not a dot, it is a regex to handle any other char or <eof> to
return from <event> state to <INITIAL> and rescan the text again.
The change below does not only add the dot for config but also for
names of groups, pmus and tracepoints (might not be complete, see
PE_NAME).
To be sure this is only valid in config syntax, add
name_config [a-zA-Z_*?][a-zA-Z0-9_*?.]*
and change name to name_config in <config>.
This should be cleaned up with name_minus by merging both.
I also think we can remove PE_NAME from event_term: at all. We need to
return PE_TERM then instead from <config>.
If you need help with the changes, I could then prepare something and
send it to you, let me know.
-Robert
>
> thanks,
> jirka
>
>
> >
> > V2: Add the dot to name too, to handle events outside cpu//
> > Acked-by: Namhyung Kim <namhyung@xxxxxxxxxx>
> > Signed-off-by: Andi Kleen <ak@xxxxxxxxxxxxxxx>
> > Signed-off-by: Sukadev Bhattiprolu <sukadev@xxxxxxxxxxxxxxxxxx>
> > ---
> > tools/perf/util/parse-events.l | 5 ++---
> > 1 file changed, 2 insertions(+), 3 deletions(-)
> >
> > diff --git a/tools/perf/util/parse-events.l b/tools/perf/util/parse-events.l
> > index 09e738f..13cef3c 100644
> > --- a/tools/perf/util/parse-events.l
> > +++ b/tools/perf/util/parse-events.l
> > @@ -119,8 +119,8 @@ event [^,{}/]+
> > num_dec [0-9]+
> > num_hex 0x[a-fA-F0-9]+
> > num_raw_hex [a-fA-F0-9]+
> > -name [a-zA-Z_*?][a-zA-Z0-9_*?]*
> > -name_minus [a-zA-Z_*?][a-zA-Z0-9\-_*?]*
> > +name [a-zA-Z_*?][a-zA-Z0-9_*?.]*
> > +name_minus [a-zA-Z_*?][a-zA-Z0-9\-_*?.]*
> > /* If you add a modifier you need to update check_modifier() */
> > modifier_event [ukhpGHSDI]+
> > modifier_bp [rwx]{1,3}
> > @@ -165,7 +165,6 @@ modifier_bp [rwx]{1,3}
> > return PE_EVENT_NAME;
> > }
> >
> > -. |
> > <<EOF>> {
> > BEGIN(INITIAL);
> > REWIND(0);
> > --
> > 1.7.9.5
> >
--
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/