trace_output.h 2.2 KB

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