blob: 4b3a3c90494f1f0f9476d403dc0ef225752cb696 [file] [log] [blame]
Jiri Olsa89812fc2012-03-15 20:09:15 +01001
2%option prefix="parse_events_"
3
4%{
5#include <errno.h>
6#include "../perf.h"
7#include "parse-events-bison.h"
Jiri Olsa8f707d82012-03-15 20:09:16 +01008#include "parse-events.h"
Jiri Olsa89812fc2012-03-15 20:09:15 +01009
10static int __value(char *str, int base, int token)
11{
12 long num;
13
14 errno = 0;
15 num = strtoul(str, NULL, base);
16 if (errno)
17 return PE_ERROR;
18
19 parse_events_lval.num = num;
20 return token;
21}
22
23static int value(int base)
24{
25 return __value(parse_events_text, base, PE_VALUE);
26}
27
28static int raw(void)
29{
30 return __value(parse_events_text + 1, 16, PE_RAW);
31}
32
Ashwin Chauguleb33e8252012-06-13 15:29:23 -040033static int sh_raw(void)
34{
35 return __value(parse_events_text + 2, 16, PE_SH_RAW);
36}
37
38static int fab_raw(void)
39{
40 return __value(parse_events_text + 2, 16, PE_FAB_RAW);
41}
42
43
Jiri Olsa89812fc2012-03-15 20:09:15 +010044static int str(int token)
45{
46 parse_events_lval.str = strdup(parse_events_text);
47 return token;
48}
49
50static int sym(int type, int config)
51{
52 parse_events_lval.num = (type << 16) + config;
53 return PE_VALUE_SYM;
54}
55
Jiri Olsa8f707d82012-03-15 20:09:16 +010056static int term(int type)
57{
58 parse_events_lval.num = type;
59 return PE_TERM;
60}
61
Jiri Olsa89812fc2012-03-15 20:09:15 +010062%}
63
64num_dec [0-9]+
65num_hex 0x[a-fA-F0-9]+
66num_raw_hex [a-fA-F0-9]+
Ashwin Chauguled803b282012-08-06 14:12:56 -040067name [a-zA-Z_*?][a-zA-Z\-0-9_*?]*
Gleb Natapove7c72d82012-04-17 14:13:45 +030068modifier_event [ukhpGH]{1,8}
Jiri Olsa89812fc2012-03-15 20:09:15 +010069modifier_bp [rwx]
70
71%%
72cpu-cycles|cycles { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_CPU_CYCLES); }
73stalled-cycles-frontend|idle-cycles-frontend { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_STALLED_CYCLES_FRONTEND); }
74stalled-cycles-backend|idle-cycles-backend { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_STALLED_CYCLES_BACKEND); }
75instructions { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_INSTRUCTIONS); }
76cache-references { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_CACHE_REFERENCES); }
77cache-misses { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_CACHE_MISSES); }
78branch-instructions|branches { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_BRANCH_INSTRUCTIONS); }
79branch-misses { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_BRANCH_MISSES); }
80bus-cycles { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_BUS_CYCLES); }
Namhyung Kimcc96aa72012-03-29 19:21:57 +090081ref-cycles { return sym(PERF_TYPE_HARDWARE, PERF_COUNT_HW_REF_CPU_CYCLES); }
Jiri Olsa89812fc2012-03-15 20:09:15 +010082cpu-clock { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_CPU_CLOCK); }
83task-clock { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_TASK_CLOCK); }
84page-faults|faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_PAGE_FAULTS); }
85minor-faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_PAGE_FAULTS_MIN); }
86major-faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_PAGE_FAULTS_MAJ); }
87context-switches|cs { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_CONTEXT_SWITCHES); }
88cpu-migrations|migrations { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_CPU_MIGRATIONS); }
89alignment-faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_ALIGNMENT_FAULTS); }
90emulation-faults { return sym(PERF_TYPE_SOFTWARE, PERF_COUNT_SW_EMULATION_FAULTS); }
91
92L1-dcache|l1-d|l1d|L1-data |
93L1-icache|l1-i|l1i|L1-instruction |
94LLC|L2 |
95dTLB|d-tlb|Data-TLB |
96iTLB|i-tlb|Instruction-TLB |
97branch|branches|bpu|btb|bpc |
98node { return str(PE_NAME_CACHE_TYPE); }
99
100load|loads|read |
101store|stores|write |
102prefetch|prefetches |
103speculative-read|speculative-load |
104refs|Reference|ops|access |
105misses|miss { return str(PE_NAME_CACHE_OP_RESULT); }
106
Jiri Olsa8f707d82012-03-15 20:09:16 +0100107 /*
108 * These are event config hardcoded term names to be specified
109 * within xxx/.../ syntax. So far we dont clash with other names,
110 * so we can put them here directly. In case the we have a conflict
111 * in future, this needs to go into '//' condition block.
112 */
113config { return term(PARSE_EVENTS__TERM_TYPE_CONFIG); }
114config1 { return term(PARSE_EVENTS__TERM_TYPE_CONFIG1); }
115config2 { return term(PARSE_EVENTS__TERM_TYPE_CONFIG2); }
116period { return term(PARSE_EVENTS__TERM_TYPE_SAMPLE_PERIOD); }
117branch_type { return term(PARSE_EVENTS__TERM_TYPE_BRANCH_SAMPLE_TYPE); }
118
Jiri Olsa89812fc2012-03-15 20:09:15 +0100119mem: { return PE_PREFIX_MEM; }
120r{num_raw_hex} { return raw(); }
Ashwin Chauguleb33e8252012-06-13 15:29:23 -0400121rs{num_raw_hex} { return sh_raw(); }
122rm{num_raw_hex} { return fab_raw(); }
Jiri Olsa89812fc2012-03-15 20:09:15 +0100123{num_dec} { return value(10); }
124{num_hex} { return value(16); }
125
126{modifier_event} { return str(PE_MODIFIER_EVENT); }
127{modifier_bp} { return str(PE_MODIFIER_BP); }
128{name} { return str(PE_NAME); }
129"/" { return '/'; }
130- { return '-'; }
131, { return ','; }
132: { return ':'; }
133= { return '='; }
134
135%%
136
137int parse_events_wrap(void)
138{
139 return 1;
140}