diff options
author | Jiri Olsa <jolsa@redhat.com> | 2012-03-15 15:09:15 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2012-03-16 13:20:21 -0400 |
commit | 89812fc81f8d62d70433a8ff63d26819f372e8ec (patch) | |
tree | 8d2c6ad6eee1200f5107fa8063a002f415887ba3 /tools/perf/util/parse-events.l | |
parent | 641cc938815dfd09f8fa1ec72deb814f0938ac33 (diff) |
perf tools: Add parser generator for events parsing
Changing event parsing to use flex/bison parse generator.
The event syntax stays as it was.
grammar description:
events: events ',' event | event
event: event_def PE_MODIFIER_EVENT | event_def
event_def: event_legacy_symbol sep_dc |
event_legacy_cache sep_dc |
event_legacy_breakpoint sep_dc |
event_legacy_tracepoint sep_dc |
event_legacy_numeric sep_dc |
event_legacy_raw sep_dc
event_legacy_symbol: PE_NAME_SYM
event_legacy_cache: PE_NAME_CACHE_TYPE '-' PE_NAME_CACHE_OP_RESULT '-' PE_NAME_CACHE_OP_RESULT |
PE_NAME_CACHE_TYPE '-' PE_NAME_CACHE_OP_RESULT |
PE_NAME_CACHE_TYPE
event_legacy_raw: PE_SEP_RAW PE_VALUE
event_legacy_numeric: PE_VALUE ':' PE_VALUE
event_legacy_breakpoint: PE_SEP_BP ':' PE_VALUE ':' PE_MODIFIER_BP
event_breakpoint_type: PE_MODIFIER_BPTYPE | empty
PE_NAME_SYM: cpu-cycles|cycles |
stalled-cycles-frontend|idle-cycles-frontend |
stalled-cycles-backend|idle-cycles-backend |
instructions |
cache-references |
cache-misses |
branch-instructions|branches |
branch-misses |
bus-cycles |
cpu-clock |
task-clock |
page-faults|faults |
minor-faults |
major-faults |
context-switches|cs |
cpu-migrations|migrations |
alignment-faults |
emulation-faults
PE_NAME_CACHE_TYPE: L1-dcache|l1-d|l1d|L1-data |
L1-icache|l1-i|l1i|L1-instruction |
LLC|L2 |
dTLB|d-tlb|Data-TLB |
iTLB|i-tlb|Instruction-TLB |
branch|branches|bpu|btb|bpc |
node
PE_NAME_CACHE_OP_RESULT: load|loads|read |
store|stores|write |
prefetch|prefetches |
speculative-read|speculative-load |
refs|Reference|ops|access |
misses|miss
PE_MODIFIER_EVENT: [ukhp]{0,5}
PE_MODIFIER_BP: [rwx]
PE_SEP_BP: 'mem'
PE_SEP_RAW: 'r'
sep_dc: ':' |
Added flex/bison files for event grammar parsing. The generated
parser is part of the patch. Added makefile rule 'event-parser'
to generate the parser code out of the bison/flex sources.
Acked-by: Peter Zijlstra <peterz@infradead.org>
Signed-off-by: Jiri Olsa <jolsa@redhat.com>
Link: http://lkml.kernel.org/n/tip-u4pfig5waq3ll2bfcdex8fgi@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/parse-events.l')
-rw-r--r-- | tools/perf/util/parse-events.l | 107 |
1 files changed, 107 insertions, 0 deletions
diff --git a/tools/perf/util/parse-events.l b/tools/perf/util/parse-events.l new file mode 100644 index 000000000000..44dbc359f0ae --- /dev/null +++ b/tools/perf/util/parse-events.l | |||
@@ -0,0 +1,107 @@ | |||
1 | |||
2 | %option prefix="parse_events_" | ||
3 | |||
4 | %{ | ||
5 | #include <errno.h> | ||
6 | #include "../perf.h" | ||
7 | #include "parse-events-bison.h" | ||
8 | |||
9 | static int __value(char *str, int base, int token) | ||
10 | { | ||
11 | long num; | ||
12 | |||
13 | errno = 0; | ||
14 | num = strtoul(str, NULL, base); | ||
15 | if (errno) | ||
16 | return PE_ERROR; | ||
17 | |||
18 | parse_events_lval.num = num; | ||
19 | return token; | ||
20 | } | ||
21 | |||
22 | static int value(int base) | ||
23 | { | ||
24 | return __value(parse_events_text, base, PE_VALUE); | ||
25 | } | ||
26 | |||
27 | static int raw(void) | ||
28 | { | ||
29 | return __value(parse_events_text + 1, 16, PE_RAW); | ||
30 | } | ||
31 | |||
32 | static int str(int token) | ||
33 | { | ||
34 | parse_events_lval.str = strdup(parse_events_text); | ||
35 | return token; | ||
36 | } | ||
37 | |||
38 | static int sym(int type, int config) | ||
39 | { | ||
40 | parse_events_lval.num = (type << 16) + config; | ||
41 | return PE_VALUE_SYM; | ||
42 | } | ||
43 | |||
44 | %} | ||
45 | |||
46 | num_dec [0-9]+ | ||
47 | num_hex 0x[a-fA-F0-9]+ | ||
48 | num_raw_hex [a-fA-F0-9]+ | ||
49 | name [a-zA-Z_*?][a-zA-Z0-9_*?]* | ||
50 | modifier_event [ukhp]{1,5} | ||
51 | modifier_bp [rwx] | ||
52 | |||
53 | %% | ||
54 | cpu-cycles|cycles { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_CPU_CYCLES); } | ||
55 | stalled-cycles-frontend|idle-cycles-frontend { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_STALLED_CYCLES_FRONTEND); } | ||
56 | stalled-cycles-backend|idle-cycles-backend { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_STALLED_CYCLES_BACKEND); } | ||
57 | instructions { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_INSTRUCTIONS); } | ||
58 | cache-references { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_CACHE_REFERENCES); } | ||
59 | cache-misses { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_CACHE_MISSES); } | ||
60 | branch-instructions|branches { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_BRANCH_INSTRUCTIONS); } | ||
61 | branch-misses { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_BRANCH_MISSES); } | ||
62 | bus-cycles { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_BUS_CYCLES); } | ||
63 | cpu-clock { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_CPU_CLOCK); } | ||
64 | task-clock { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_TASK_CLOCK); } | ||
65 | page-faults|faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_PAGE_FAULTS); } | ||
66 | minor-faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_PAGE_FAULTS_MIN); } | ||
67 | major-faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_PAGE_FAULTS_MAJ); } | ||
68 | context-switches|cs { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_CONTEXT_SWITCHES); } | ||
69 | cpu-migrations|migrations { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_CPU_MIGRATIONS); } | ||
70 | alignment-faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_ALIGNMENT_FAULTS); } | ||
71 | emulation-faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_EMULATION_FAULTS); } | ||
72 | |||
73 | L1-dcache|l1-d|l1d|L1-data | | ||
74 | L1-icache|l1-i|l1i|L1-instruction | | ||
75 | LLC|L2 | | ||
76 | dTLB|d-tlb|Data-TLB | | ||
77 | iTLB|i-tlb|Instruction-TLB | | ||
78 | branch|branches|bpu|btb|bpc | | ||
79 | node { return str(PE_NAME_CACHE_TYPE); } | ||
80 | |||
81 | load|loads|read | | ||
82 | store|stores|write | | ||
83 | prefetch|prefetches | | ||
84 | speculative-read|speculative-load | | ||
85 | refs|Reference|ops|access | | ||
86 | misses|miss { return str(PE_NAME_CACHE_OP_RESULT); } | ||
87 | |||
88 | mem: { return PE_PREFIX_MEM; } | ||
89 | r{num_raw_hex} { return raw(); } | ||
90 | {num_dec} { return value(10); } | ||
91 | {num_hex} { return value(16); } | ||
92 | |||
93 | {modifier_event} { return str(PE_MODIFIER_EVENT); } | ||
94 | {modifier_bp} { return str(PE_MODIFIER_BP); } | ||
95 | {name} { return str(PE_NAME); } | ||
96 | "/" { return '/'; } | ||
97 | - { return '-'; } | ||
98 | , { return ','; } | ||
99 | : { return ':'; } | ||
100 | = { return '='; } | ||
101 | |||
102 | %% | ||
103 | |||
104 | int parse_events_wrap(void) | ||
105 | { | ||
106 | return 1; | ||
107 | } | ||