diff options
author | Jiri Olsa <jolsa@kernel.org> | 2016-02-14 11:03:42 -0500 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2016-02-16 15:12:56 -0500 |
commit | 975f14fa8f2996604f248552eee4403def34bf5e (patch) | |
tree | b1e32a5c9b34b50f6c6748b13e08e08da25cf0bf /tools/lib/api/debug.c | |
parent | d646ae0a73deb0d80792a6a9c0757317ad8049c5 (diff) |
tools lib api: Add debug output support
Adding support for warning/info/debug output within libapi code. Adding
following macros:
pr_warning(fmt, ...)
pr_info(fmt, ...)
pr_debug(fmt, ...)
Also adding libapi_set_print function to set above functions. This will
be used in perf to set standard debug handlers for libapi.
Adding 2 header files:
debug.h
- to be used outside libapi, contains
libapi_set_print interface
debug-internal.h
- to be used within libapi, contains
pr_warning/pr_info/pr_debug definitions
Signed-off-by: Jiri Olsa <jolsa@kernel.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/1455465826-8426-2-git-send-email-jolsa@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/lib/api/debug.c')
-rw-r--r-- | tools/lib/api/debug.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/tools/lib/api/debug.c b/tools/lib/api/debug.c new file mode 100644 index 000000000000..5fa5cf500a1f --- /dev/null +++ b/tools/lib/api/debug.c | |||
@@ -0,0 +1,28 @@ | |||
1 | #include <stdio.h> | ||
2 | #include <stdarg.h> | ||
3 | #include "debug.h" | ||
4 | #include "debug-internal.h" | ||
5 | |||
6 | static int __base_pr(const char *format, ...) | ||
7 | { | ||
8 | va_list args; | ||
9 | int err; | ||
10 | |||
11 | va_start(args, format); | ||
12 | err = vfprintf(stderr, format, args); | ||
13 | va_end(args); | ||
14 | return err; | ||
15 | } | ||
16 | |||
17 | libapi_print_fn_t __pr_warning = __base_pr; | ||
18 | libapi_print_fn_t __pr_info = __base_pr; | ||
19 | libapi_print_fn_t __pr_debug; | ||
20 | |||
21 | void libapi_set_print(libapi_print_fn_t warn, | ||
22 | libapi_print_fn_t info, | ||
23 | libapi_print_fn_t debug) | ||
24 | { | ||
25 | __pr_warning = warn; | ||
26 | __pr_info = info; | ||
27 | __pr_debug = debug; | ||
28 | } | ||