trace_output.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. #ifndef __TRACE_EVENTS_H
  2. #define __TRACE_EVENTS_H
  3. #include "trace.h"
  4. typedef enum print_line_t (*trace_print_func)(struct trace_iterator *iter,
  5. int flags);
  6. struct trace_event {
  7. struct hlist_node node;
  8. int type;
  9. trace_print_func trace;
  10. trace_print_func latency_trace;
  11. trace_print_func raw;
  12. trace_print_func hex;
  13. trace_print_func binary;
  14. };
  15. extern int trace_seq_printf(struct trace_seq *s, const char *fmt, ...)
  16. __attribute__ ((format (printf, 2, 3)));
  17. extern int
  18. seq_print_ip_sym(struct trace_seq *s, unsigned long ip,
  19. unsigned long sym_flags);
  20. extern ssize_t trace_seq_to_user(struct trace_seq *s, char __user *ubuf,
  21. size_t cnt);
  22. int trace_seq_puts(struct trace_seq *s, const char *str);
  23. int trace_seq_putc(struct trace_seq *s, unsigned char c);
  24. int trace_seq_putmem(struct trace_seq *s, void *mem, size_t len);
  25. int trace_seq_putmem_hex(struct trace_seq *s, void *mem, size_t len);
  26. int trace_seq_path(struct trace_seq *s, struct path *path);
  27. int seq_print_userip_objs(const struct userstack_entry *entry,
  28. struct trace_seq *s, unsigned long sym_flags);
  29. int seq_print_user_ip(struct trace_seq *s, struct mm_struct *mm,
  30. unsigned long ip, unsigned long sym_flags);
  31. int trace_print_context(struct trace_iterator *iter);
  32. int trace_print_lat_context(struct trace_iterator *iter);
  33. struct trace_event *ftrace_find_event(int type);
  34. int register_ftrace_event(struct trace_event *event);
  35. int unregister_ftrace_event(struct trace_event *event);
  36. enum print_line_t trace_nop_print(struct trace_iterator *iter, int flags);
  37. #define MAX_MEMHEX_BYTES 8
  38. #define HEX_CHARS (MAX_MEMHEX_BYTES*2 + 1)
  39. #define SEQ_PUT_FIELD_RET(s, x) \
  40. do { \
  41. if (!trace_seq_putmem(s, &(x), sizeof(x))) \
  42. return TRACE_TYPE_PARTIAL_LINE; \
  43. } while (0)
  44. #define SEQ_PUT_HEX_FIELD_RET(s, x) \
  45. do { \
  46. BUILD_BUG_ON(sizeof(x) > MAX_MEMHEX_BYTES); \
  47. if (!trace_seq_putmem_hex(s, &(x), sizeof(x))) \
  48. return TRACE_TYPE_PARTIAL_LINE; \
  49. } while (0)
  50. #endif