trace-event.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. #ifndef _TRACE_EVENTS_H
  2. #define _TRACE_EVENTS_H
  3. #include "parse-events.h"
  4. #define __unused __attribute__((unused))
  5. #ifndef PAGE_MASK
  6. #define PAGE_MASK (page_size - 1)
  7. #endif
  8. enum {
  9. RINGBUF_TYPE_PADDING = 29,
  10. RINGBUF_TYPE_TIME_EXTEND = 30,
  11. RINGBUF_TYPE_TIME_STAMP = 31,
  12. };
  13. #ifndef TS_SHIFT
  14. #define TS_SHIFT 27
  15. #endif
  16. #define NSECS_PER_SEC 1000000000ULL
  17. #define NSECS_PER_USEC 1000ULL
  18. enum format_flags {
  19. FIELD_IS_ARRAY = 1,
  20. FIELD_IS_POINTER = 2,
  21. };
  22. struct format_field {
  23. struct format_field *next;
  24. char *type;
  25. char *name;
  26. int offset;
  27. int size;
  28. unsigned long flags;
  29. };
  30. struct format {
  31. int nr_common;
  32. int nr_fields;
  33. struct format_field *common_fields;
  34. struct format_field *fields;
  35. };
  36. struct print_arg_atom {
  37. char *atom;
  38. };
  39. struct print_arg_string {
  40. char *string;
  41. int offset;
  42. };
  43. struct print_arg_field {
  44. char *name;
  45. struct format_field *field;
  46. };
  47. struct print_flag_sym {
  48. struct print_flag_sym *next;
  49. char *value;
  50. char *str;
  51. };
  52. struct print_arg_typecast {
  53. char *type;
  54. struct print_arg *item;
  55. };
  56. struct print_arg_flags {
  57. struct print_arg *field;
  58. char *delim;
  59. struct print_flag_sym *flags;
  60. };
  61. struct print_arg_symbol {
  62. struct print_arg *field;
  63. struct print_flag_sym *symbols;
  64. };
  65. struct print_arg;
  66. struct print_arg_op {
  67. char *op;
  68. int prio;
  69. struct print_arg *left;
  70. struct print_arg *right;
  71. };
  72. struct print_arg_func {
  73. char *name;
  74. struct print_arg *args;
  75. };
  76. enum print_arg_type {
  77. PRINT_NULL,
  78. PRINT_ATOM,
  79. PRINT_FIELD,
  80. PRINT_FLAGS,
  81. PRINT_SYMBOL,
  82. PRINT_TYPE,
  83. PRINT_STRING,
  84. PRINT_OP,
  85. };
  86. struct print_arg {
  87. struct print_arg *next;
  88. enum print_arg_type type;
  89. union {
  90. struct print_arg_atom atom;
  91. struct print_arg_field field;
  92. struct print_arg_typecast typecast;
  93. struct print_arg_flags flags;
  94. struct print_arg_symbol symbol;
  95. struct print_arg_func func;
  96. struct print_arg_string string;
  97. struct print_arg_op op;
  98. };
  99. };
  100. struct print_fmt {
  101. char *format;
  102. struct print_arg *args;
  103. };
  104. struct event {
  105. struct event *next;
  106. char *name;
  107. int id;
  108. int flags;
  109. struct format format;
  110. struct print_fmt print_fmt;
  111. };
  112. enum {
  113. EVENT_FL_ISFTRACE = 1,
  114. EVENT_FL_ISPRINT = 2,
  115. EVENT_FL_ISBPRINT = 4,
  116. EVENT_FL_ISFUNC = 8,
  117. EVENT_FL_ISFUNCENT = 16,
  118. EVENT_FL_ISFUNCRET = 32,
  119. };
  120. struct record {
  121. unsigned long long ts;
  122. int size;
  123. void *data;
  124. };
  125. struct record *trace_peek_data(int cpu);
  126. struct record *trace_read_data(int cpu);
  127. void parse_set_info(int nr_cpus, int long_sz);
  128. void trace_report(void);
  129. void *malloc_or_die(unsigned int size);
  130. void parse_cmdlines(char *file, int size);
  131. void parse_proc_kallsyms(char *file, unsigned int size);
  132. void parse_ftrace_printk(char *file, unsigned int size);
  133. void print_funcs(void);
  134. void print_printk(void);
  135. int parse_ftrace_file(char *buf, unsigned long size);
  136. int parse_event_file(char *buf, unsigned long size, char *system);
  137. void print_event(int cpu, void *data, int size, unsigned long long nsecs,
  138. char *comm);
  139. extern int file_bigendian;
  140. extern int host_bigendian;
  141. int bigendian(void);
  142. static inline unsigned short __data2host2(unsigned short data)
  143. {
  144. unsigned short swap;
  145. if (host_bigendian == file_bigendian)
  146. return data;
  147. swap = ((data & 0xffULL) << 8) |
  148. ((data & (0xffULL << 8)) >> 8);
  149. return swap;
  150. }
  151. static inline unsigned int __data2host4(unsigned int data)
  152. {
  153. unsigned int swap;
  154. if (host_bigendian == file_bigendian)
  155. return data;
  156. swap = ((data & 0xffULL) << 24) |
  157. ((data & (0xffULL << 8)) << 8) |
  158. ((data & (0xffULL << 16)) >> 8) |
  159. ((data & (0xffULL << 24)) >> 24);
  160. return swap;
  161. }
  162. static inline unsigned long long __data2host8(unsigned long long data)
  163. {
  164. unsigned long long swap;
  165. if (host_bigendian == file_bigendian)
  166. return data;
  167. swap = ((data & 0xffULL) << 56) |
  168. ((data & (0xffULL << 8)) << 40) |
  169. ((data & (0xffULL << 16)) << 24) |
  170. ((data & (0xffULL << 24)) << 8) |
  171. ((data & (0xffULL << 32)) >> 8) |
  172. ((data & (0xffULL << 40)) >> 24) |
  173. ((data & (0xffULL << 48)) >> 40) |
  174. ((data & (0xffULL << 56)) >> 56);
  175. return swap;
  176. }
  177. #define data2host2(ptr) __data2host2(*(unsigned short *)ptr)
  178. #define data2host4(ptr) __data2host4(*(unsigned int *)ptr)
  179. #define data2host8(ptr) __data2host8(*(unsigned long long *)ptr)
  180. extern int header_page_ts_offset;
  181. extern int header_page_ts_size;
  182. extern int header_page_size_offset;
  183. extern int header_page_size_size;
  184. extern int header_page_data_offset;
  185. extern int header_page_data_size;
  186. int parse_header_page(char *buf, unsigned long size);
  187. int trace_parse_common_type(void *data);
  188. struct event *trace_find_event(int id);
  189. unsigned long long
  190. raw_field_value(struct event *event, const char *name, void *data);
  191. void *raw_field_ptr(struct event *event, const char *name, void *data);
  192. void read_tracing_data(struct perf_event_attr *pattrs, int nb_events);
  193. #endif /* _TRACE_EVENTS_H */