debug.h 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /* For debugging general purposes */
  3. #ifndef __PERF_DEBUG_H
  4. #define __PERF_DEBUG_H
  5. #include <stdbool.h>
  6. #include <string.h>
  7. #include <linux/compiler.h>
  8. #include "event.h"
  9. #include "../ui/helpline.h"
  10. #include "../ui/progress.h"
  11. #include "../ui/util.h"
  12. extern int verbose;
  13. extern bool quiet, dump_trace;
  14. extern int debug_ordered_events;
  15. extern int debug_data_convert;
  16. #ifndef pr_fmt
  17. #define pr_fmt(fmt) fmt
  18. #endif
  19. #define pr_err(fmt, ...) \
  20. eprintf(0, verbose, pr_fmt(fmt), ##__VA_ARGS__)
  21. #define pr_warning(fmt, ...) \
  22. eprintf(0, verbose, pr_fmt(fmt), ##__VA_ARGS__)
  23. #define pr_info(fmt, ...) \
  24. eprintf(0, verbose, pr_fmt(fmt), ##__VA_ARGS__)
  25. #define pr_debug(fmt, ...) \
  26. eprintf(1, verbose, pr_fmt(fmt), ##__VA_ARGS__)
  27. #define pr_debugN(n, fmt, ...) \
  28. eprintf(n, verbose, pr_fmt(fmt), ##__VA_ARGS__)
  29. #define pr_debug2(fmt, ...) pr_debugN(2, pr_fmt(fmt), ##__VA_ARGS__)
  30. #define pr_debug3(fmt, ...) pr_debugN(3, pr_fmt(fmt), ##__VA_ARGS__)
  31. #define pr_debug4(fmt, ...) pr_debugN(4, pr_fmt(fmt), ##__VA_ARGS__)
  32. #define pr_time_N(n, var, t, fmt, ...) \
  33. eprintf_time(n, var, t, fmt, ##__VA_ARGS__)
  34. #define pr_oe_time(t, fmt, ...) pr_time_N(1, debug_ordered_events, t, pr_fmt(fmt), ##__VA_ARGS__)
  35. #define pr_oe_time2(t, fmt, ...) pr_time_N(2, debug_ordered_events, t, pr_fmt(fmt), ##__VA_ARGS__)
  36. #define STRERR_BUFSIZE 128 /* For the buffer size of str_error_r */
  37. int dump_printf(const char *fmt, ...) __printf(1, 2);
  38. void trace_event(union perf_event *event);
  39. int ui__error(const char *format, ...) __printf(1, 2);
  40. int ui__warning(const char *format, ...) __printf(1, 2);
  41. void pr_stat(const char *fmt, ...);
  42. int eprintf(int level, int var, const char *fmt, ...) __printf(3, 4);
  43. int eprintf_time(int level, int var, u64 t, const char *fmt, ...) __printf(4, 5);
  44. int veprintf(int level, int var, const char *fmt, va_list args);
  45. int perf_debug_option(const char *str);
  46. void perf_debug_setup(void);
  47. int perf_quiet_option(void);
  48. void dump_stack(void);
  49. void sighandler_dump_stack(int sig);
  50. #endif /* __PERF_DEBUG_H */