Commit 8abceacf authored by Jiri Olsa's avatar Jiri Olsa Committed by Arnaldo Carvalho de Melo

perf debug: Add debug_set_file function

Allow to set debug output file via new debug_set_file function.

It's called during perf startup in perf_debug_setup to set stderr file
as default and any perf command can set it later to different file.

It will be used in perf daemon command to get verbose output into log
file.
Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Alexei Budankov <abudankov@huawei.com>
Cc: Ian Rogers <irogers@google.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Michael Petlan <mpetlan@redhat.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lore.kernel.org/lkml/20201212104358.412065-2-jolsa@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 7cfcd1e0
...@@ -30,6 +30,12 @@ bool dump_trace = false, quiet = false; ...@@ -30,6 +30,12 @@ bool dump_trace = false, quiet = false;
int debug_ordered_events; int debug_ordered_events;
static int redirect_to_stderr; static int redirect_to_stderr;
int debug_data_convert; int debug_data_convert;
static FILE *debug_file;
void debug_set_file(FILE *file)
{
debug_file = file;
}
int veprintf(int level, int var, const char *fmt, va_list args) int veprintf(int level, int var, const char *fmt, va_list args)
{ {
...@@ -39,7 +45,7 @@ int veprintf(int level, int var, const char *fmt, va_list args) ...@@ -39,7 +45,7 @@ int veprintf(int level, int var, const char *fmt, va_list args)
if (use_browser >= 1 && !redirect_to_stderr) if (use_browser >= 1 && !redirect_to_stderr)
ui_helpline__vshow(fmt, args); ui_helpline__vshow(fmt, args);
else else
ret = vfprintf(stderr, fmt, args); ret = vfprintf(debug_file, fmt, args);
} }
return ret; return ret;
...@@ -227,6 +233,7 @@ DEBUG_WRAPPER(debug, 1); ...@@ -227,6 +233,7 @@ DEBUG_WRAPPER(debug, 1);
void perf_debug_setup(void) void perf_debug_setup(void)
{ {
debug_set_file(stderr);
libapi_set_print(pr_warning_wrapper, pr_warning_wrapper, pr_debug_wrapper); libapi_set_print(pr_warning_wrapper, pr_warning_wrapper, pr_debug_wrapper);
} }
......
...@@ -5,6 +5,7 @@ ...@@ -5,6 +5,7 @@
#include <stdarg.h> #include <stdarg.h>
#include <stdbool.h> #include <stdbool.h>
#include <stdio.h>
#include <linux/compiler.h> #include <linux/compiler.h>
extern int verbose; extern int verbose;
...@@ -62,6 +63,7 @@ int eprintf_time(int level, int var, u64 t, const char *fmt, ...) __printf(4, 5) ...@@ -62,6 +63,7 @@ int eprintf_time(int level, int var, u64 t, const char *fmt, ...) __printf(4, 5)
int veprintf(int level, int var, const char *fmt, va_list args); int veprintf(int level, int var, const char *fmt, va_list args);
int perf_debug_option(const char *str); int perf_debug_option(const char *str);
void debug_set_file(FILE *file);
void perf_debug_setup(void); void perf_debug_setup(void);
int perf_quiet_option(void); int perf_quiet_option(void);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment