trace-event.h 3.0 KB

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