~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/tools/lib/traceevent/event-parse.h

Version: ~ [ linux-5.0-rc2 ] ~ [ linux-4.20.2 ] ~ [ linux-4.19.15 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.93 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.150 ] ~ [ linux-4.8.17 ] ~ [ linux-4.7.10 ] ~ [ linux-4.6.7 ] ~ [ linux-4.5.7 ] ~ [ linux-4.4.170 ] ~ [ linux-4.3.6 ] ~ [ linux-4.2.8 ] ~ [ linux-4.1.52 ] ~ [ linux-4.0.9 ] ~ [ linux-3.19.8 ] ~ [ linux-3.18.132 ] ~ [ linux-3.17.8 ] ~ [ linux-3.16.62 ] ~ [ linux-3.15.10 ] ~ [ linux-3.14.79 ] ~ [ linux-3.13.11 ] ~ [ linux-3.12.74 ] ~ [ linux-3.11.10 ] ~ [ linux-3.10.108 ] ~ [ linux-3.9.11 ] ~ [ linux-3.8.13 ] ~ [ linux-3.7.10 ] ~ [ linux-3.6.11 ] ~ [ linux-3.5.7 ] ~ [ linux-3.4.113 ] ~ [ linux-3.3.8 ] ~ [ linux-3.2.102 ] ~ [ linux-3.1.10 ] ~ [ linux-3.0.101 ] ~ [ linux-2.6.39.4 ] ~ [ linux-2.6.38.8 ] ~ [ linux-2.6.37.6 ] ~ [ linux-2.6.36.4 ] ~ [ linux-2.6.35.14 ] ~ [ linux-2.6.34.15 ] ~ [ linux-2.6.33.20 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.5 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /*
  2  * Copyright (C) 2009, 2010 Red Hat Inc, Steven Rostedt <srostedt@redhat.com>
  3  *
  4  * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  5  * This program is free software; you can redistribute it and/or
  6  * modify it under the terms of the GNU Lesser General Public
  7  * License as published by the Free Software Foundation;
  8  * version 2.1 of the License (not later!)
  9  *
 10  * This program is distributed in the hope that it will be useful,
 11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 13  * GNU Lesser General Public License for more details.
 14  *
 15  * You should have received a copy of the GNU Lesser General Public
 16  * License along with this program; if not,  see <http://www.gnu.org/licenses>
 17  *
 18  * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 19  */
 20 #ifndef _PARSE_EVENTS_H
 21 #define _PARSE_EVENTS_H
 22 
 23 #include <stdbool.h>
 24 #include <stdarg.h>
 25 #include <stdio.h>
 26 #include <regex.h>
 27 #include <string.h>
 28 
 29 #include "trace-seq.h"
 30 
 31 #ifndef __maybe_unused
 32 #define __maybe_unused __attribute__((unused))
 33 #endif
 34 
 35 #ifndef DEBUG_RECORD
 36 #define DEBUG_RECORD 0
 37 #endif
 38 
 39 struct tep_record {
 40         unsigned long long      ts;
 41         unsigned long long      offset;
 42         long long               missed_events;  /* buffer dropped events before */
 43         int                     record_size;    /* size of binary record */
 44         int                     size;           /* size of data */
 45         void                    *data;
 46         int                     cpu;
 47         int                     ref_count;
 48         int                     locked;         /* Do not free, even if ref_count is zero */
 49         void                    *priv;
 50 #if DEBUG_RECORD
 51         struct tep_record       *prev;
 52         struct tep_record       *next;
 53         long                    alloc_addr;
 54 #endif
 55 };
 56 
 57 /* ----------------------- tep ----------------------- */
 58 
 59 struct tep_handle;
 60 struct tep_event;
 61 
 62 typedef int (*tep_event_handler_func)(struct trace_seq *s,
 63                                       struct tep_record *record,
 64                                       struct tep_event *event,
 65                                       void *context);
 66 
 67 typedef int (*tep_plugin_load_func)(struct tep_handle *pevent);
 68 typedef int (*tep_plugin_unload_func)(struct tep_handle *pevent);
 69 
 70 struct tep_plugin_option {
 71         struct tep_plugin_option        *next;
 72         void                            *handle;
 73         char                            *file;
 74         char                            *name;
 75         char                            *plugin_alias;
 76         char                            *description;
 77         const char                      *value;
 78         void                            *priv;
 79         int                             set;
 80 };
 81 
 82 /*
 83  * Plugin hooks that can be called:
 84  *
 85  * TEP_PLUGIN_LOADER:  (required)
 86  *   The function name to initialized the plugin.
 87  *
 88  *   int TEP_PLUGIN_LOADER(struct tep_handle *pevent)
 89  *
 90  * TEP_PLUGIN_UNLOADER:  (optional)
 91  *   The function called just before unloading
 92  *
 93  *   int TEP_PLUGIN_UNLOADER(struct tep_handle *pevent)
 94  *
 95  * TEP_PLUGIN_OPTIONS:  (optional)
 96  *   Plugin options that can be set before loading
 97  *
 98  *   struct tep_plugin_option TEP_PLUGIN_OPTIONS[] = {
 99  *      {
100  *              .name = "option-name",
101  *              .plugin_alias = "override-file-name", (optional)
102  *              .description = "description of option to show users",
103  *      },
104  *      {
105  *              .name = NULL,
106  *      },
107  *   };
108  *
109  *   Array must end with .name = NULL;
110  *
111  *
112  *   .plugin_alias is used to give a shorter name to access
113  *   the vairable. Useful if a plugin handles more than one event.
114  *
115  *   If .value is not set, then it is considered a boolean and only
116  *   .set will be processed. If .value is defined, then it is considered
117  *   a string option and .set will be ignored.
118  *
119  * TEP_PLUGIN_ALIAS: (optional)
120  *   The name to use for finding options (uses filename if not defined)
121  */
122 #define TEP_PLUGIN_LOADER tep_plugin_loader
123 #define TEP_PLUGIN_UNLOADER tep_plugin_unloader
124 #define TEP_PLUGIN_OPTIONS tep_plugin_options
125 #define TEP_PLUGIN_ALIAS tep_plugin_alias
126 #define _MAKE_STR(x)    #x
127 #define MAKE_STR(x)     _MAKE_STR(x)
128 #define TEP_PLUGIN_LOADER_NAME MAKE_STR(TEP_PLUGIN_LOADER)
129 #define TEP_PLUGIN_UNLOADER_NAME MAKE_STR(TEP_PLUGIN_UNLOADER)
130 #define TEP_PLUGIN_OPTIONS_NAME MAKE_STR(TEP_PLUGIN_OPTIONS)
131 #define TEP_PLUGIN_ALIAS_NAME MAKE_STR(TEP_PLUGIN_ALIAS)
132 
133 enum tep_format_flags {
134         TEP_FIELD_IS_ARRAY      = 1,
135         TEP_FIELD_IS_POINTER    = 2,
136         TEP_FIELD_IS_SIGNED     = 4,
137         TEP_FIELD_IS_STRING     = 8,
138         TEP_FIELD_IS_DYNAMIC    = 16,
139         TEP_FIELD_IS_LONG       = 32,
140         TEP_FIELD_IS_FLAG       = 64,
141         TEP_FIELD_IS_SYMBOLIC   = 128,
142 };
143 
144 struct tep_format_field {
145         struct tep_format_field *next;
146         struct tep_event        *event;
147         char                    *type;
148         char                    *name;
149         char                    *alias;
150         int                     offset;
151         int                     size;
152         unsigned int            arraylen;
153         unsigned int            elementsize;
154         unsigned long           flags;
155 };
156 
157 struct tep_format {
158         int                     nr_common;
159         int                     nr_fields;
160         struct tep_format_field *common_fields;
161         struct tep_format_field *fields;
162 };
163 
164 struct tep_print_arg_atom {
165         char                    *atom;
166 };
167 
168 struct tep_print_arg_string {
169         char                    *string;
170         int                     offset;
171 };
172 
173 struct tep_print_arg_bitmask {
174         char                    *bitmask;
175         int                     offset;
176 };
177 
178 struct tep_print_arg_field {
179         char                    *name;
180         struct tep_format_field *field;
181 };
182 
183 struct tep_print_flag_sym {
184         struct tep_print_flag_sym       *next;
185         char                            *value;
186         char                            *str;
187 };
188 
189 struct tep_print_arg_typecast {
190         char                    *type;
191         struct tep_print_arg    *item;
192 };
193 
194 struct tep_print_arg_flags {
195         struct tep_print_arg            *field;
196         char                            *delim;
197         struct tep_print_flag_sym       *flags;
198 };
199 
200 struct tep_print_arg_symbol {
201         struct tep_print_arg            *field;
202         struct tep_print_flag_sym       *symbols;
203 };
204 
205 struct tep_print_arg_hex {
206         struct tep_print_arg    *field;
207         struct tep_print_arg    *size;
208 };
209 
210 struct tep_print_arg_int_array {
211         struct tep_print_arg    *field;
212         struct tep_print_arg    *count;
213         struct tep_print_arg    *el_size;
214 };
215 
216 struct tep_print_arg_dynarray {
217         struct tep_format_field *field;
218         struct tep_print_arg    *index;
219 };
220 
221 struct tep_print_arg;
222 
223 struct tep_print_arg_op {
224         char                    *op;
225         int                     prio;
226         struct tep_print_arg    *left;
227         struct tep_print_arg    *right;
228 };
229 
230 struct tep_function_handler;
231 
232 struct tep_print_arg_func {
233         struct tep_function_handler     *func;
234         struct tep_print_arg            *args;
235 };
236 
237 enum tep_print_arg_type {
238         TEP_PRINT_NULL,
239         TEP_PRINT_ATOM,
240         TEP_PRINT_FIELD,
241         TEP_PRINT_FLAGS,
242         TEP_PRINT_SYMBOL,
243         TEP_PRINT_HEX,
244         TEP_PRINT_INT_ARRAY,
245         TEP_PRINT_TYPE,
246         TEP_PRINT_STRING,
247         TEP_PRINT_BSTRING,
248         TEP_PRINT_DYNAMIC_ARRAY,
249         TEP_PRINT_OP,
250         TEP_PRINT_FUNC,
251         TEP_PRINT_BITMASK,
252         TEP_PRINT_DYNAMIC_ARRAY_LEN,
253         TEP_PRINT_HEX_STR,
254 };
255 
256 struct tep_print_arg {
257         struct tep_print_arg            *next;
258         enum tep_print_arg_type         type;
259         union {
260                 struct tep_print_arg_atom       atom;
261                 struct tep_print_arg_field      field;
262                 struct tep_print_arg_typecast   typecast;
263                 struct tep_print_arg_flags      flags;
264                 struct tep_print_arg_symbol     symbol;
265                 struct tep_print_arg_hex        hex;
266                 struct tep_print_arg_int_array  int_array;
267                 struct tep_print_arg_func       func;
268                 struct tep_print_arg_string     string;
269                 struct tep_print_arg_bitmask    bitmask;
270                 struct tep_print_arg_op         op;
271                 struct tep_print_arg_dynarray   dynarray;
272         };
273 };
274 
275 struct tep_print_fmt {
276         char                    *format;
277         struct tep_print_arg    *args;
278 };
279 
280 struct tep_event {
281         struct tep_handle       *pevent;
282         char                    *name;
283         int                     id;
284         int                     flags;
285         struct tep_format       format;
286         struct tep_print_fmt    print_fmt;
287         char                    *system;
288         tep_event_handler_func  handler;
289         void                    *context;
290 };
291 
292 enum {
293         TEP_EVENT_FL_ISFTRACE   = 0x01,
294         TEP_EVENT_FL_ISPRINT    = 0x02,
295         TEP_EVENT_FL_ISBPRINT   = 0x04,
296         TEP_EVENT_FL_ISFUNCENT  = 0x10,
297         TEP_EVENT_FL_ISFUNCRET  = 0x20,
298         TEP_EVENT_FL_NOHANDLE   = 0x40,
299         TEP_EVENT_FL_PRINTRAW   = 0x80,
300 
301         TEP_EVENT_FL_FAILED     = 0x80000000
302 };
303 
304 enum tep_event_sort_type {
305         TEP_EVENT_SORT_ID,
306         TEP_EVENT_SORT_NAME,
307         TEP_EVENT_SORT_SYSTEM,
308 };
309 
310 enum tep_event_type {
311         TEP_EVENT_ERROR,
312         TEP_EVENT_NONE,
313         TEP_EVENT_SPACE,
314         TEP_EVENT_NEWLINE,
315         TEP_EVENT_OP,
316         TEP_EVENT_DELIM,
317         TEP_EVENT_ITEM,
318         TEP_EVENT_DQUOTE,
319         TEP_EVENT_SQUOTE,
320 };
321 
322 typedef unsigned long long (*tep_func_handler)(struct trace_seq *s,
323                                                unsigned long long *args);
324 
325 enum tep_func_arg_type {
326         TEP_FUNC_ARG_VOID,
327         TEP_FUNC_ARG_INT,
328         TEP_FUNC_ARG_LONG,
329         TEP_FUNC_ARG_STRING,
330         TEP_FUNC_ARG_PTR,
331         TEP_FUNC_ARG_MAX_TYPES
332 };
333 
334 enum tep_flag {
335         TEP_NSEC_OUTPUT         = 1,    /* output in NSECS */
336         TEP_DISABLE_SYS_PLUGINS = 1 << 1,
337         TEP_DISABLE_PLUGINS     = 1 << 2,
338 };
339 
340 #define TEP_ERRORS                                                            \
341         _PE(MEM_ALLOC_FAILED,   "failed to allocate memory"),                 \
342         _PE(PARSE_EVENT_FAILED, "failed to parse event"),                     \
343         _PE(READ_ID_FAILED,     "failed to read event id"),                   \
344         _PE(READ_FORMAT_FAILED, "failed to read event format"),               \
345         _PE(READ_PRINT_FAILED,  "failed to read event print fmt"),            \
346         _PE(OLD_FTRACE_ARG_FAILED,"failed to allocate field name for ftrace"),\
347         _PE(INVALID_ARG_TYPE,   "invalid argument type"),                     \
348         _PE(INVALID_EXP_TYPE,   "invalid expression type"),                   \
349         _PE(INVALID_OP_TYPE,    "invalid operator type"),                     \
350         _PE(INVALID_EVENT_NAME, "invalid event name"),                        \
351         _PE(EVENT_NOT_FOUND,    "no event found"),                            \
352         _PE(SYNTAX_ERROR,       "syntax error"),                              \
353         _PE(ILLEGAL_RVALUE,     "illegal rvalue"),                            \
354         _PE(ILLEGAL_LVALUE,     "illegal lvalue for string comparison"),      \
355         _PE(INVALID_REGEX,      "regex did not compute"),                     \
356         _PE(ILLEGAL_STRING_CMP, "illegal comparison for string"),             \
357         _PE(ILLEGAL_INTEGER_CMP,"illegal comparison for integer"),            \
358         _PE(REPARENT_NOT_OP,    "cannot reparent other than OP"),             \
359         _PE(REPARENT_FAILED,    "failed to reparent filter OP"),              \
360         _PE(BAD_FILTER_ARG,     "bad arg in filter tree"),                    \
361         _PE(UNEXPECTED_TYPE,    "unexpected type (not a value)"),             \
362         _PE(ILLEGAL_TOKEN,      "illegal token"),                             \
363         _PE(INVALID_PAREN,      "open parenthesis cannot come here"),         \
364         _PE(UNBALANCED_PAREN,   "unbalanced number of parenthesis"),          \
365         _PE(UNKNOWN_TOKEN,      "unknown token"),                             \
366         _PE(FILTER_NOT_FOUND,   "no filter found"),                           \
367         _PE(NOT_A_NUMBER,       "must have number field"),                    \
368         _PE(NO_FILTER,          "no filters exists"),                         \
369         _PE(FILTER_MISS,        "record does not match to filter")
370 
371 #undef _PE
372 #define _PE(__code, __str) TEP_ERRNO__ ## __code
373 enum tep_errno {
374         TEP_ERRNO__SUCCESS                      = 0,
375         TEP_ERRNO__FILTER_MATCH                 = TEP_ERRNO__SUCCESS,
376 
377         /*
378          * Choose an arbitrary negative big number not to clash with standard
379          * errno since SUS requires the errno has distinct positive values.
380          * See 'Issue 6' in the link below.
381          *
382          * http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/errno.h.html
383          */
384         __TEP_ERRNO__START                      = -100000,
385 
386         TEP_ERRORS,
387 
388         __TEP_ERRNO__END,
389 };
390 #undef _PE
391 
392 struct tep_plugin_list;
393 
394 #define INVALID_PLUGIN_LIST_OPTION      ((char **)((unsigned long)-1))
395 
396 struct tep_plugin_list *tep_load_plugins(struct tep_handle *pevent);
397 void tep_unload_plugins(struct tep_plugin_list *plugin_list,
398                         struct tep_handle *pevent);
399 char **tep_plugin_list_options(void);
400 void tep_plugin_free_options_list(char **list);
401 int tep_plugin_add_options(const char *name,
402                            struct tep_plugin_option *options);
403 void tep_plugin_remove_options(struct tep_plugin_option *options);
404 void tep_print_plugins(struct trace_seq *s,
405                         const char *prefix, const char *suffix,
406                         const struct tep_plugin_list *list);
407 
408 /* tep_handle */
409 typedef char *(tep_func_resolver_t)(void *priv,
410                                     unsigned long long *addrp, char **modp);
411 void tep_set_flag(struct tep_handle *tep, int flag);
412 
413 static inline int tep_host_bigendian(void)
414 {
415         unsigned char str[] = { 0x1, 0x2, 0x3, 0x4 };
416         unsigned int val;
417 
418         memcpy(&val, str, 4);
419         return val == 0x01020304;
420 }
421 
422 /* taken from kernel/trace/trace.h */
423 enum trace_flag_type {
424         TRACE_FLAG_IRQS_OFF             = 0x01,
425         TRACE_FLAG_IRQS_NOSUPPORT       = 0x02,
426         TRACE_FLAG_NEED_RESCHED         = 0x04,
427         TRACE_FLAG_HARDIRQ              = 0x08,
428         TRACE_FLAG_SOFTIRQ              = 0x10,
429 };
430 
431 int tep_set_function_resolver(struct tep_handle *pevent,
432                               tep_func_resolver_t *func, void *priv);
433 void tep_reset_function_resolver(struct tep_handle *pevent);
434 int tep_register_comm(struct tep_handle *pevent, const char *comm, int pid);
435 int tep_override_comm(struct tep_handle *pevent, const char *comm, int pid);
436 int tep_register_trace_clock(struct tep_handle *pevent, const char *trace_clock);
437 int tep_register_function(struct tep_handle *pevent, char *name,
438                           unsigned long long addr, char *mod);
439 int tep_register_print_string(struct tep_handle *pevent, const char *fmt,
440                               unsigned long long addr);
441 int tep_pid_is_registered(struct tep_handle *pevent, int pid);
442 
443 void tep_print_event_task(struct tep_handle *pevent, struct trace_seq *s,
444                           struct tep_event *event,
445                           struct tep_record *record);
446 void tep_print_event_time(struct tep_handle *pevent, struct trace_seq *s,
447                           struct tep_event *event,
448                           struct tep_record *record,
449                           bool use_trace_clock);
450 void tep_print_event_data(struct tep_handle *pevent, struct trace_seq *s,
451                           struct tep_event *event,
452                           struct tep_record *record);
453 void tep_print_event(struct tep_handle *pevent, struct trace_seq *s,
454                      struct tep_record *record, bool use_trace_clock);
455 
456 int tep_parse_header_page(struct tep_handle *pevent, char *buf, unsigned long size,
457                           int long_size);
458 
459 enum tep_errno tep_parse_event(struct tep_handle *pevent, const char *buf,
460                                unsigned long size, const char *sys);
461 enum tep_errno tep_parse_format(struct tep_handle *pevent,
462                                 struct tep_event **eventp,
463                                 const char *buf,
464                                 unsigned long size, const char *sys);
465 
466 void *tep_get_field_raw(struct trace_seq *s, struct tep_event *event,
467                         const char *name, struct tep_record *record,
468                         int *len, int err);
469 
470 int tep_get_field_val(struct trace_seq *s, struct tep_event *event,
471                       const char *name, struct tep_record *record,
472                       unsigned long long *val, int err);
473 int tep_get_common_field_val(struct trace_seq *s, struct tep_event *event,
474                              const char *name, struct tep_record *record,
475                              unsigned long long *val, int err);
476 int tep_get_any_field_val(struct trace_seq *s, struct tep_event *event,
477                           const char *name, struct tep_record *record,
478                           unsigned long long *val, int err);
479 
480 int tep_print_num_field(struct trace_seq *s, const char *fmt,
481                         struct tep_event *event, const char *name,
482                         struct tep_record *record, int err);
483 
484 int tep_print_func_field(struct trace_seq *s, const char *fmt,
485                          struct tep_event *event, const char *name,
486                          struct tep_record *record, int err);
487 
488 enum tep_reg_handler {
489         TEP_REGISTER_SUCCESS = 0,
490         TEP_REGISTER_SUCCESS_OVERWRITE,
491 };
492 
493 int tep_register_event_handler(struct tep_handle *pevent, int id,
494                                const char *sys_name, const char *event_name,
495                                tep_event_handler_func func, void *context);
496 int tep_unregister_event_handler(struct tep_handle *pevent, int id,
497                                  const char *sys_name, const char *event_name,
498                                  tep_event_handler_func func, void *context);
499 int tep_register_print_function(struct tep_handle *pevent,
500                                 tep_func_handler func,
501                                 enum tep_func_arg_type ret_type,
502                                 char *name, ...);
503 int tep_unregister_print_function(struct tep_handle *pevent,
504                                   tep_func_handler func, char *name);
505 
506 struct tep_format_field *tep_find_common_field(struct tep_event *event, const char *name);
507 struct tep_format_field *tep_find_field(struct tep_event *event, const char *name);
508 struct tep_format_field *tep_find_any_field(struct tep_event *event, const char *name);
509 
510 const char *tep_find_function(struct tep_handle *pevent, unsigned long long addr);
511 unsigned long long
512 tep_find_function_address(struct tep_handle *pevent, unsigned long long addr);
513 unsigned long long tep_read_number(struct tep_handle *pevent, const void *ptr, int size);
514 int tep_read_number_field(struct tep_format_field *field, const void *data,
515                           unsigned long long *value);
516 
517 struct tep_event *tep_get_first_event(struct tep_handle *tep);
518 int tep_get_events_count(struct tep_handle *tep);
519 struct tep_event *tep_find_event(struct tep_handle *pevent, int id);
520 
521 struct tep_event *
522 tep_find_event_by_name(struct tep_handle *pevent, const char *sys, const char *name);
523 struct tep_event *
524 tep_find_event_by_record(struct tep_handle *pevent, struct tep_record *record);
525 
526 void tep_data_lat_fmt(struct tep_handle *pevent,
527                       struct trace_seq *s, struct tep_record *record);
528 int tep_data_type(struct tep_handle *pevent, struct tep_record *rec);
529 int tep_data_pid(struct tep_handle *pevent, struct tep_record *rec);
530 int tep_data_preempt_count(struct tep_handle *pevent, struct tep_record *rec);
531 int tep_data_flags(struct tep_handle *pevent, struct tep_record *rec);
532 const char *tep_data_comm_from_pid(struct tep_handle *pevent, int pid);
533 struct tep_cmdline;
534 struct tep_cmdline *tep_data_pid_from_comm(struct tep_handle *pevent, const char *comm,
535                                            struct tep_cmdline *next);
536 int tep_cmdline_pid(struct tep_handle *pevent, struct tep_cmdline *cmdline);
537 
538 void tep_print_field(struct trace_seq *s, void *data,
539                      struct tep_format_field *field);
540 void tep_print_fields(struct trace_seq *s, void *data,
541                       int size __maybe_unused, struct tep_event *event);
542 void tep_event_info(struct trace_seq *s, struct tep_event *event,
543                     struct tep_record *record);
544 int tep_strerror(struct tep_handle *pevent, enum tep_errno errnum,
545                  char *buf, size_t buflen);
546 
547 struct tep_event **tep_list_events(struct tep_handle *pevent, enum tep_event_sort_type);
548 struct tep_format_field **tep_event_common_fields(struct tep_event *event);
549 struct tep_format_field **tep_event_fields(struct tep_event *event);
550 
551 enum tep_endian {
552         TEP_LITTLE_ENDIAN = 0,
553         TEP_BIG_ENDIAN
554 };
555 int tep_get_cpus(struct tep_handle *pevent);
556 void tep_set_cpus(struct tep_handle *pevent, int cpus);
557 int tep_get_long_size(struct tep_handle *pevent);
558 void tep_set_long_size(struct tep_handle *pevent, int long_size);
559 int tep_get_page_size(struct tep_handle *pevent);
560 void tep_set_page_size(struct tep_handle *pevent, int _page_size);
561 int tep_file_bigendian(struct tep_handle *pevent);
562 void tep_set_file_bigendian(struct tep_handle *pevent, enum tep_endian endian);
563 int tep_is_host_bigendian(struct tep_handle *pevent);
564 void tep_set_host_bigendian(struct tep_handle *pevent, enum tep_endian endian);
565 int tep_is_latency_format(struct tep_handle *pevent);
566 void tep_set_latency_format(struct tep_handle *pevent, int lat);
567 int tep_get_header_page_size(struct tep_handle *pevent);
568 
569 struct tep_handle *tep_alloc(void);
570 void tep_free(struct tep_handle *pevent);
571 void tep_ref(struct tep_handle *pevent);
572 void tep_unref(struct tep_handle *pevent);
573 int tep_get_ref(struct tep_handle *tep);
574 
575 /* access to the internal parser */
576 void tep_buffer_init(const char *buf, unsigned long long size);
577 enum tep_event_type tep_read_token(char **tok);
578 void tep_free_token(char *token);
579 int tep_peek_char(void);
580 const char *tep_get_input_buf(void);
581 unsigned long long tep_get_input_buf_ptr(void);
582 
583 /* for debugging */
584 void tep_print_funcs(struct tep_handle *pevent);
585 void tep_print_printk(struct tep_handle *pevent);
586 
587 /* ----------------------- filtering ----------------------- */
588 
589 enum tep_filter_boolean_type {
590         TEP_FILTER_FALSE,
591         TEP_FILTER_TRUE,
592 };
593 
594 enum tep_filter_op_type {
595         TEP_FILTER_OP_AND = 1,
596         TEP_FILTER_OP_OR,
597         TEP_FILTER_OP_NOT,
598 };
599 
600 enum tep_filter_cmp_type {
601         TEP_FILTER_CMP_NONE,
602         TEP_FILTER_CMP_EQ,
603         TEP_FILTER_CMP_NE,
604         TEP_FILTER_CMP_GT,
605         TEP_FILTER_CMP_LT,
606         TEP_FILTER_CMP_GE,
607         TEP_FILTER_CMP_LE,
608         TEP_FILTER_CMP_MATCH,
609         TEP_FILTER_CMP_NOT_MATCH,
610         TEP_FILTER_CMP_REGEX,
611         TEP_FILTER_CMP_NOT_REGEX,
612 };
613 
614 enum tep_filter_exp_type {
615         TEP_FILTER_EXP_NONE,
616         TEP_FILTER_EXP_ADD,
617         TEP_FILTER_EXP_SUB,
618         TEP_FILTER_EXP_MUL,
619         TEP_FILTER_EXP_DIV,
620         TEP_FILTER_EXP_MOD,
621         TEP_FILTER_EXP_RSHIFT,
622         TEP_FILTER_EXP_LSHIFT,
623         TEP_FILTER_EXP_AND,
624         TEP_FILTER_EXP_OR,
625         TEP_FILTER_EXP_XOR,
626         TEP_FILTER_EXP_NOT,
627 };
628 
629 enum tep_filter_arg_type {
630         TEP_FILTER_ARG_NONE,
631         TEP_FILTER_ARG_BOOLEAN,
632         TEP_FILTER_ARG_VALUE,
633         TEP_FILTER_ARG_FIELD,
634         TEP_FILTER_ARG_EXP,
635         TEP_FILTER_ARG_OP,
636         TEP_FILTER_ARG_NUM,
637         TEP_FILTER_ARG_STR,
638 };
639 
640 enum tep_filter_value_type {
641         TEP_FILTER_NUMBER,
642         TEP_FILTER_STRING,
643         TEP_FILTER_CHAR
644 };
645 
646 struct tep_filter_arg;
647 
648 struct tep_filter_arg_boolean {
649         enum tep_filter_boolean_type    value;
650 };
651 
652 struct tep_filter_arg_field {
653         struct tep_format_field         *field;
654 };
655 
656 struct tep_filter_arg_value {
657         enum tep_filter_value_type      type;
658         union {
659                 char                    *str;
660                 unsigned long long      val;
661         };
662 };
663 
664 struct tep_filter_arg_op {
665         enum tep_filter_op_type         type;
666         struct tep_filter_arg           *left;
667         struct tep_filter_arg           *right;
668 };
669 
670 struct tep_filter_arg_exp {
671         enum tep_filter_exp_type        type;
672         struct tep_filter_arg           *left;
673         struct tep_filter_arg           *right;
674 };
675 
676 struct tep_filter_arg_num {
677         enum tep_filter_cmp_type        type;
678         struct tep_filter_arg           *left;
679         struct tep_filter_arg           *right;
680 };
681 
682 struct tep_filter_arg_str {
683         enum tep_filter_cmp_type        type;
684         struct tep_format_field         *field;
685         char                            *val;
686         char                            *buffer;
687         regex_t                         reg;
688 };
689 
690 struct tep_filter_arg {
691         enum tep_filter_arg_type                type;
692         union {
693                 struct tep_filter_arg_boolean   boolean;
694                 struct tep_filter_arg_field     field;
695                 struct tep_filter_arg_value     value;
696                 struct tep_filter_arg_op        op;
697                 struct tep_filter_arg_exp       exp;
698                 struct tep_filter_arg_num       num;
699                 struct tep_filter_arg_str       str;
700         };
701 };
702 
703 struct tep_filter_type {
704         int                     event_id;
705         struct tep_event        *event;
706         struct tep_filter_arg   *filter;
707 };
708 
709 #define TEP_FILTER_ERROR_BUFSZ  1024
710 
711 struct tep_event_filter {
712         struct tep_handle       *pevent;
713         int                     filters;
714         struct tep_filter_type  *event_filters;
715         char                    error_buffer[TEP_FILTER_ERROR_BUFSZ];
716 };
717 
718 struct tep_event_filter *tep_filter_alloc(struct tep_handle *pevent);
719 
720 /* for backward compatibility */
721 #define FILTER_NONE             TEP_ERRNO__NO_FILTER
722 #define FILTER_NOEXIST          TEP_ERRNO__FILTER_NOT_FOUND
723 #define FILTER_MISS             TEP_ERRNO__FILTER_MISS
724 #define FILTER_MATCH            TEP_ERRNO__FILTER_MATCH
725 
726 enum tep_filter_trivial_type {
727         TEP_FILTER_TRIVIAL_FALSE,
728         TEP_FILTER_TRIVIAL_TRUE,
729         TEP_FILTER_TRIVIAL_BOTH,
730 };
731 
732 enum tep_errno tep_filter_add_filter_str(struct tep_event_filter *filter,
733                                          const char *filter_str);
734 
735 enum tep_errno tep_filter_match(struct tep_event_filter *filter,
736                                 struct tep_record *record);
737 
738 int tep_filter_strerror(struct tep_event_filter *filter, enum tep_errno err,
739                         char *buf, size_t buflen);
740 
741 int tep_event_filtered(struct tep_event_filter *filter,
742                        int event_id);
743 
744 void tep_filter_reset(struct tep_event_filter *filter);
745 
746 int tep_filter_clear_trivial(struct tep_event_filter *filter,
747                              enum tep_filter_trivial_type type);
748 
749 void tep_filter_free(struct tep_event_filter *filter);
750 
751 char *tep_filter_make_string(struct tep_event_filter *filter, int event_id);
752 
753 int tep_filter_remove_event(struct tep_event_filter *filter,
754                             int event_id);
755 
756 int tep_filter_event_has_trivial(struct tep_event_filter *filter,
757                                  int event_id,
758                                  enum tep_filter_trivial_type type);
759 
760 int tep_filter_copy(struct tep_event_filter *dest, struct tep_event_filter *source);
761 
762 int tep_update_trivial(struct tep_event_filter *dest, struct tep_event_filter *source,
763                         enum tep_filter_trivial_type type);
764 
765 int tep_filter_compare(struct tep_event_filter *filter1, struct tep_event_filter *filter2);
766 
767 #endif /* _PARSE_EVENTS_H */
768 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | Wiki (Japanese) | Wiki (English) | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

osdn.jp