syscall.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. #ifndef _TRACE_SYSCALL_H
  2. #define _TRACE_SYSCALL_H
  3. #include <linux/tracepoint.h>
  4. #include <linux/unistd.h>
  5. #include <linux/ftrace_event.h>
  6. #include <asm/ptrace.h>
  7. #ifdef CONFIG_HAVE_SYSCALL_TRACEPOINTS
  8. extern void syscall_regfunc(void);
  9. extern void syscall_unregfunc(void);
  10. DECLARE_TRACE_WITH_CALLBACK(syscall_enter,
  11. TP_PROTO(struct pt_regs *regs, long id),
  12. TP_ARGS(regs, id),
  13. syscall_regfunc,
  14. syscall_unregfunc
  15. );
  16. DECLARE_TRACE_WITH_CALLBACK(syscall_exit,
  17. TP_PROTO(struct pt_regs *regs, long ret),
  18. TP_ARGS(regs, ret),
  19. syscall_regfunc,
  20. syscall_unregfunc
  21. );
  22. #endif
  23. /*
  24. * A syscall entry in the ftrace syscalls array.
  25. *
  26. * @name: name of the syscall
  27. * @nb_args: number of parameters it takes
  28. * @types: list of types as strings
  29. * @args: list of args as strings (args[i] matches types[i])
  30. * @enter_id: associated ftrace enter event id
  31. * @exit_id: associated ftrace exit event id
  32. * @enter_event: associated syscall_enter trace event
  33. * @exit_event: associated syscall_exit trace event
  34. */
  35. struct syscall_metadata {
  36. const char *name;
  37. int nb_args;
  38. const char **types;
  39. const char **args;
  40. int enter_id;
  41. int exit_id;
  42. struct ftrace_event_call *enter_event;
  43. struct ftrace_event_call *exit_event;
  44. };
  45. #ifdef CONFIG_FTRACE_SYSCALLS
  46. extern struct syscall_metadata *syscall_nr_to_meta(int nr);
  47. extern int syscall_name_to_nr(char *name);
  48. void set_syscall_enter_id(int num, int id);
  49. void set_syscall_exit_id(int num, int id);
  50. extern struct trace_event event_syscall_enter;
  51. extern struct trace_event event_syscall_exit;
  52. extern int reg_event_syscall_enter(void *ptr);
  53. extern void unreg_event_syscall_enter(void *ptr);
  54. extern int reg_event_syscall_exit(void *ptr);
  55. extern void unreg_event_syscall_exit(void *ptr);
  56. extern int syscall_enter_format(struct ftrace_event_call *call,
  57. struct trace_seq *s);
  58. extern int syscall_exit_format(struct ftrace_event_call *call,
  59. struct trace_seq *s);
  60. extern int syscall_enter_define_fields(struct ftrace_event_call *call);
  61. extern int syscall_exit_define_fields(struct ftrace_event_call *call);
  62. enum print_line_t print_syscall_enter(struct trace_iterator *iter, int flags);
  63. enum print_line_t print_syscall_exit(struct trace_iterator *iter, int flags);
  64. #endif
  65. #ifdef CONFIG_EVENT_PROFILE
  66. int reg_prof_syscall_enter(char *name);
  67. void unreg_prof_syscall_enter(char *name);
  68. int reg_prof_syscall_exit(char *name);
  69. void unreg_prof_syscall_exit(char *name);
  70. #endif
  71. #endif /* _TRACE_SYSCALL_H */