trace_output.h 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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. extern int trace_seq_puts(struct trace_seq *s, const char *str);
  28. extern int trace_seq_putc(struct trace_seq *s, unsigned char c);
  29. extern int trace_seq_putmem(struct trace_seq *s, const void *mem, size_t len);
  30. extern int trace_seq_putmem_hex(struct trace_seq *s, const void *mem,
  31. size_t len);
  32. extern void *trace_seq_reserve(struct trace_seq *s, size_t len);
  33. extern int trace_seq_path(struct trace_seq *s, struct path *path);
  34. extern int seq_print_userip_objs(const struct userstack_entry *entry,
  35. struct trace_seq *s, unsigned long sym_flags);
  36. extern int seq_print_user_ip(struct trace_seq *s, struct mm_struct *mm,
  37. unsigned long ip, unsigned long sym_flags);
  38. extern int trace_print_context(struct trace_iterator *iter);
  39. extern int trace_print_lat_context(struct trace_iterator *iter);
  40. extern struct trace_event *ftrace_find_event(int type);
  41. extern int register_ftrace_event(struct trace_event *event);
  42. extern int unregister_ftrace_event(struct trace_event *event);
  43. extern enum print_line_t trace_nop_print(struct trace_iterator *iter,
  44. int flags);
  45. #define MAX_MEMHEX_BYTES 8
  46. #define HEX_CHARS (MAX_MEMHEX_BYTES*2 + 1)
  47. #define SEQ_PUT_FIELD_RET(s, x) \
  48. do { \
  49. if (!trace_seq_putmem(s, &(x), sizeof(x))) \
  50. return TRACE_TYPE_PARTIAL_LINE; \
  51. } while (0)
  52. #define SEQ_PUT_HEX_FIELD_RET(s, x) \
  53. do { \
  54. BUILD_BUG_ON(sizeof(x) > MAX_MEMHEX_BYTES); \
  55. if (!trace_seq_putmem_hex(s, &(x), sizeof(x))) \
  56. return TRACE_TYPE_PARTIAL_LINE; \
  57. } while (0)
  58. #endif