trace-event.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. #ifndef _PERF_UTIL_TRACE_EVENT_H
  2. #define _PERF_UTIL_TRACE_EVENT_H
  3. #include <traceevent/event-parse.h>
  4. #include "parse-events.h"
  5. #include "session.h"
  6. struct machine;
  7. struct perf_sample;
  8. union perf_event;
  9. struct perf_tool;
  10. extern bool latency_format;
  11. extern struct pevent *perf_pevent;
  12. enum {
  13. RINGBUF_TYPE_PADDING = 29,
  14. RINGBUF_TYPE_TIME_EXTEND = 30,
  15. RINGBUF_TYPE_TIME_STAMP = 31,
  16. };
  17. #ifndef TS_SHIFT
  18. #define TS_SHIFT 27
  19. #endif
  20. int bigendian(void);
  21. struct pevent *read_trace_init(int file_bigendian, int host_bigendian);
  22. void event_format__print(struct event_format *event,
  23. int cpu, void *data, int size);
  24. int parse_ftrace_file(struct pevent *pevent, char *buf, unsigned long size);
  25. int parse_event_file(struct pevent *pevent,
  26. char *buf, unsigned long size, char *sys);
  27. struct pevent_record *trace_peek_data(struct pevent *pevent, int cpu);
  28. unsigned long long
  29. raw_field_value(struct event_format *event, const char *name, void *data);
  30. void *raw_field_ptr(struct event_format *event, const char *name, void *data);
  31. void parse_proc_kallsyms(struct pevent *pevent, char *file, unsigned int size);
  32. void parse_ftrace_printk(struct pevent *pevent, char *file, unsigned int size);
  33. ssize_t trace_report(int fd, struct pevent **pevent, bool repipe);
  34. int trace_parse_common_type(struct pevent *pevent, void *data);
  35. int trace_parse_common_pid(struct pevent *pevent, void *data);
  36. struct event_format *trace_find_next_event(struct pevent *pevent,
  37. struct event_format *event);
  38. unsigned long long read_size(struct event_format *event, void *ptr, int size);
  39. unsigned long long eval_flag(const char *flag);
  40. struct pevent_record *trace_read_data(struct pevent *pevent, int cpu);
  41. int read_tracing_data(int fd, struct list_head *pattrs);
  42. struct tracing_data {
  43. /* size is only valid if temp is 'true' */
  44. ssize_t size;
  45. bool temp;
  46. char temp_file[50];
  47. };
  48. struct tracing_data *tracing_data_get(struct list_head *pattrs,
  49. int fd, bool temp);
  50. int tracing_data_put(struct tracing_data *tdata);
  51. struct addr_location;
  52. struct perf_session;
  53. struct scripting_ops {
  54. const char *name;
  55. int (*start_script) (const char *script, int argc, const char **argv);
  56. int (*stop_script) (void);
  57. void (*process_event) (union perf_event *event,
  58. struct perf_sample *sample,
  59. struct perf_evsel *evsel,
  60. struct machine *machine,
  61. struct addr_location *al);
  62. int (*generate_script) (struct pevent *pevent, const char *outfile);
  63. };
  64. int script_spec_register(const char *spec, struct scripting_ops *ops);
  65. void setup_perl_scripting(void);
  66. void setup_python_scripting(void);
  67. struct scripting_context {
  68. struct pevent *pevent;
  69. void *event_data;
  70. };
  71. int common_pc(struct scripting_context *context);
  72. int common_flags(struct scripting_context *context);
  73. int common_lock_depth(struct scripting_context *context);
  74. #endif /* _PERF_UTIL_TRACE_EVENT_H */