1 // SPDX-License-Identifier: GPL-2.0-only
2
3 #define __printf(a, b) __attribute__((format(printf, a, b)))
4
5 #include <stdio.h>
6 #include <stdarg.h>
7 #include <unistd.h>
8 #include <linux/compiler.h>
9 #include <perf/core.h>
10 #include <internal/lib.h>
11 #include "internal.h"
12
__base_pr(enum libperf_print_level level __maybe_unused,const char * format,va_list args)13 static int __base_pr(enum libperf_print_level level __maybe_unused, const char *format,
14 va_list args)
15 {
16 return vfprintf(stderr, format, args);
17 }
18
19 static libperf_print_fn_t __libperf_pr = __base_pr;
20
21 __printf(2, 3)
libperf_print(enum libperf_print_level level,const char * format,...)22 void libperf_print(enum libperf_print_level level, const char *format, ...)
23 {
24 va_list args;
25
26 if (!__libperf_pr)
27 return;
28
29 va_start(args, format);
30 __libperf_pr(level, format, args);
31 va_end(args);
32 }
33
libperf_init(libperf_print_fn_t fn)34 void libperf_init(libperf_print_fn_t fn)
35 {
36 page_size = sysconf(_SC_PAGE_SIZE);
37 __libperf_pr = fn;
38 }
39