static pid_t target_pid = 0;
static bool emit_timestamp = false;
+static bool verbose = false;
const char *argp_program_version = "solisten 0.1";
const char *argp_program_bug_address =
" solisten -p 1216 # only trace PID 1216\n";
static const struct argp_option opts[] = {
- {"pid", 'p', "PID", 0, "Process ID to trace"},
- {"timestamp", 't', NULL, 0, "Include timestamp on output"},
- {NULL, 'h', NULL, OPTION_HIDDEN, "Show the full help"},
+ { "pid", 'p', "PID", 0, "Process ID to trace" },
+ { "timestamp", 't', NULL, 0, "Include timestamp on output" },
+ { "verbose", 'v', NULL, 0, "Verbose debug output" },
+ { NULL, 'h', NULL, OPTION_HIDDEN, "Show the full help" },
{},
};
case 't':
emit_timestamp = true;
break;
+ case 'v':
+ verbose = true;
+ break;
case 'h':
argp_state_help(state, stderr, ARGP_HELP_STD_HELP);
break;
return 0;
}
+static int libbpf_print_fn(enum libbpf_print_level level, const char *format, va_list args)
+{
+ if (level == LIBBPF_DEBUG && !verbose)
+ return 0;
+ return vfprintf(stderr, format, args);
+}
+
static void sig_int(int signo)
{
exiting = 1;
return err;
libbpf_set_strict_mode(LIBBPF_STRICT_ALL);
+ libbpf_set_print(libbpf_print_fn);
obj = solisten_bpf__open();
if (!obj) {