tools/bpf: simplify libbpf API function libbpf_set_print()
Currently, the libbpf API function libbpf_set_print() takes three function pointer parameters for warning, info and debug printout respectively. This patch changes the API to have just one function pointer parameter and the function pointer has one additional parameter "debugging level". So if in the future, if the debug level is increased, the function signature won't change. Signed-off-by: Yonghong Song <yhs@fb.com> Signed-off-by: Alexei Starovoitov <ast@kernel.org>
This commit is contained in:

committed by
Alexei Starovoitov

parent
9d100a19ff
commit
6f1ae8b662
@@ -54,29 +54,26 @@
|
||||
|
||||
#define __printf(a, b) __attribute__((format(printf, a, b)))
|
||||
|
||||
__printf(1, 2)
|
||||
static int __base_pr(const char *format, ...)
|
||||
__printf(2, 3)
|
||||
static int __base_pr(enum libbpf_print_level level, const char *format, ...)
|
||||
{
|
||||
va_list args;
|
||||
int err;
|
||||
|
||||
if (level == LIBBPF_DEBUG)
|
||||
return 0;
|
||||
|
||||
va_start(args, format);
|
||||
err = vfprintf(stderr, format, args);
|
||||
va_end(args);
|
||||
return err;
|
||||
}
|
||||
|
||||
static __printf(1, 2) libbpf_print_fn_t __pr_warning = __base_pr;
|
||||
static __printf(1, 2) libbpf_print_fn_t __pr_info = __base_pr;
|
||||
static __printf(1, 2) libbpf_print_fn_t __pr_debug;
|
||||
static __printf(2, 3) libbpf_print_fn_t __libbpf_pr = __base_pr;
|
||||
|
||||
void libbpf_set_print(libbpf_print_fn_t warn,
|
||||
libbpf_print_fn_t info,
|
||||
libbpf_print_fn_t debug)
|
||||
void libbpf_set_print(libbpf_print_fn_t fn)
|
||||
{
|
||||
__pr_warning = warn;
|
||||
__pr_info = info;
|
||||
__pr_debug = debug;
|
||||
__libbpf_pr = fn;
|
||||
}
|
||||
|
||||
__printf(2, 3)
|
||||
@@ -84,17 +81,11 @@ void libbpf_print(enum libbpf_print_level level, const char *format, ...)
|
||||
{
|
||||
va_list args;
|
||||
|
||||
if (!__libbpf_pr)
|
||||
return;
|
||||
|
||||
va_start(args, format);
|
||||
if (level == LIBBPF_WARN) {
|
||||
if (__pr_warning)
|
||||
__pr_warning(format, args);
|
||||
} else if (level == LIBBPF_INFO) {
|
||||
if (__pr_info)
|
||||
__pr_info(format, args);
|
||||
} else {
|
||||
if (__pr_debug)
|
||||
__pr_debug(format, args);
|
||||
}
|
||||
__libbpf_pr(level, format, args);
|
||||
va_end(args);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user