]>
Commit | Line | Data |
---|---|---|
cd84c2ac | 1 | /* For debugging general purposes */ |
8b40f521 JK |
2 | #ifndef __PERF_DEBUG_H |
3 | #define __PERF_DEBUG_H | |
cd84c2ac | 4 | |
c0555642 | 5 | #include <stdbool.h> |
b2348e1d | 6 | #include <string.h> |
afaed6d3 | 7 | #include <linux/compiler.h> |
8f41146a | 8 | #include "event.h" |
0985a948 | 9 | #include "../ui/helpline.h" |
75291420 NK |
10 | #include "../ui/progress.h" |
11 | #include "../ui/util.h" | |
8f41146a | 12 | |
cd84c2ac | 13 | extern int verbose; |
b44308f5 | 14 | extern bool quiet, dump_trace; |
cee3ab9c | 15 | extern int debug_ordered_events; |
edbe9817 | 16 | extern int debug_data_convert; |
cd84c2ac | 17 | |
84f5d36f JO |
18 | #ifndef pr_fmt |
19 | #define pr_fmt(fmt) fmt | |
20 | #endif | |
21 | ||
22 | #define pr_err(fmt, ...) \ | |
c95688aa | 23 | eprintf(0, verbose, pr_fmt(fmt), ##__VA_ARGS__) |
84f5d36f | 24 | #define pr_warning(fmt, ...) \ |
c95688aa | 25 | eprintf(0, verbose, pr_fmt(fmt), ##__VA_ARGS__) |
84f5d36f | 26 | #define pr_info(fmt, ...) \ |
c95688aa | 27 | eprintf(0, verbose, pr_fmt(fmt), ##__VA_ARGS__) |
84f5d36f | 28 | #define pr_debug(fmt, ...) \ |
c95688aa | 29 | eprintf(1, verbose, pr_fmt(fmt), ##__VA_ARGS__) |
84f5d36f | 30 | #define pr_debugN(n, fmt, ...) \ |
c95688aa | 31 | eprintf(n, verbose, pr_fmt(fmt), ##__VA_ARGS__) |
84f5d36f JO |
32 | #define pr_debug2(fmt, ...) pr_debugN(2, pr_fmt(fmt), ##__VA_ARGS__) |
33 | #define pr_debug3(fmt, ...) pr_debugN(3, pr_fmt(fmt), ##__VA_ARGS__) | |
34 | #define pr_debug4(fmt, ...) pr_debugN(4, pr_fmt(fmt), ##__VA_ARGS__) | |
35 | ||
cee3ab9c JO |
36 | #define pr_time_N(n, var, t, fmt, ...) \ |
37 | eprintf_time(n, var, t, fmt, ##__VA_ARGS__) | |
38 | ||
39 | #define pr_oe_time(t, fmt, ...) pr_time_N(1, debug_ordered_events, t, pr_fmt(fmt), ##__VA_ARGS__) | |
40 | #define pr_oe_time2(t, fmt, ...) pr_time_N(2, debug_ordered_events, t, pr_fmt(fmt), ##__VA_ARGS__) | |
41 | ||
c8b5f2c9 | 42 | #define STRERR_BUFSIZE 128 /* For the buffer size of str_error_r */ |
b2348e1d | 43 | |
afaed6d3 | 44 | int dump_printf(const char *fmt, ...) __printf(1, 2); |
8115d60c | 45 | void trace_event(union perf_event *event); |
567e5479 | 46 | |
afaed6d3 ACM |
47 | int ui__error(const char *format, ...) __printf(1, 2); |
48 | int ui__warning(const char *format, ...) __printf(1, 2); | |
068ffaa8 | 49 | |
f772abc6 JO |
50 | void pr_stat(const char *fmt, ...); |
51 | ||
afaed6d3 ACM |
52 | int eprintf(int level, int var, const char *fmt, ...) __printf(3, 4); |
53 | int eprintf_time(int level, int var, u64 t, const char *fmt, ...) __printf(4, 5); | |
0af0885e | 54 | int veprintf(int level, int var, const char *fmt, va_list args); |
84f5d36f | 55 | |
bbb2cea7 | 56 | int perf_debug_option(const char *str); |
dd629cc0 | 57 | void perf_debug_setup(void); |
80df1988 | 58 | int perf_quiet_option(void); |
bbb2cea7 | 59 | |
8c2b7cac ACM |
60 | void dump_stack(void); |
61 | void sighandler_dump_stack(int sig); | |
62 | ||
8b40f521 | 63 | #endif /* __PERF_DEBUG_H */ |