Commit e03eaa40 authored by David Ahern's avatar David Ahern Committed by Arnaldo Carvalho de Melo

perf tools: Add pid/tid filtering to report and script commands

The 'record' and 'top' tools already allow a user to specify a CSV of
pids and/or tids of tasks to collect data.

Add those options to the 'report' and 'script' analysis commands to only
consider samples related to the given pids/tids.

This is also inline with the existing comm option.
Signed-off-by: default avatarDavid Ahern <dsahern@gmail.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/r/1427212361-7066-1-git-send-email-dsahern@gmail.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 6b1f3423
...@@ -40,6 +40,11 @@ OPTIONS ...@@ -40,6 +40,11 @@ OPTIONS
Only consider symbols in these comms. CSV that understands Only consider symbols in these comms. CSV that understands
file://filename entries. This option will affect the percentage of file://filename entries. This option will affect the percentage of
the overhead column. See --percentage for more info. the overhead column. See --percentage for more info.
--pid=::
Only show events for given process ID (comma separated list).
--tid=::
Only show events for given thread ID (comma separated list).
-d:: -d::
--dsos=:: --dsos=::
Only consider symbols in these dsos. CSV that understands Only consider symbols in these dsos. CSV that understands
......
...@@ -193,6 +193,12 @@ OPTIONS ...@@ -193,6 +193,12 @@ OPTIONS
Only display events for these comms. CSV that understands Only display events for these comms. CSV that understands
file://filename entries. file://filename entries.
--pid=::
Only show events for given process ID (comma separated list).
--tid=::
Only show events for given thread ID (comma separated list).
-I:: -I::
--show-info:: --show-info::
Display extended information about the perf.data file. This adds Display extended information about the perf.data file. This adds
......
...@@ -669,6 +669,10 @@ int cmd_report(int argc, const char **argv, const char *prefix __maybe_unused) ...@@ -669,6 +669,10 @@ int cmd_report(int argc, const char **argv, const char *prefix __maybe_unused)
"only consider symbols in these dsos"), "only consider symbols in these dsos"),
OPT_STRING('c', "comms", &symbol_conf.comm_list_str, "comm[,comm...]", OPT_STRING('c', "comms", &symbol_conf.comm_list_str, "comm[,comm...]",
"only consider symbols in these comms"), "only consider symbols in these comms"),
OPT_STRING(0, "pid", &symbol_conf.pid_list_str, "pid[,pid...]",
"only consider symbols in these pids"),
OPT_STRING(0, "tid", &symbol_conf.tid_list_str, "tid[,tid...]",
"only consider symbols in these tids"),
OPT_STRING('S', "symbols", &symbol_conf.sym_list_str, "symbol[,symbol...]", OPT_STRING('S', "symbols", &symbol_conf.sym_list_str, "symbol[,symbol...]",
"only consider these symbols"), "only consider these symbols"),
OPT_STRING(0, "symbol-filter", &report.symbol_filter_str, "filter", OPT_STRING(0, "symbol-filter", &report.symbol_filter_str, "filter",
......
...@@ -1562,6 +1562,10 @@ int cmd_script(int argc, const char **argv, const char *prefix __maybe_unused) ...@@ -1562,6 +1562,10 @@ int cmd_script(int argc, const char **argv, const char *prefix __maybe_unused)
OPT_STRING('C', "cpu", &cpu_list, "cpu", "list of cpus to profile"), OPT_STRING('C', "cpu", &cpu_list, "cpu", "list of cpus to profile"),
OPT_STRING('c', "comms", &symbol_conf.comm_list_str, "comm[,comm...]", OPT_STRING('c', "comms", &symbol_conf.comm_list_str, "comm[,comm...]",
"only display events for these comms"), "only display events for these comms"),
OPT_STRING(0, "pid", &symbol_conf.pid_list_str, "pid[,pid...]",
"only consider symbols in these pids"),
OPT_STRING(0, "tid", &symbol_conf.tid_list_str, "tid[,tid...]",
"only consider symbols in these tids"),
OPT_BOOLEAN('I', "show-info", &show_full_info, OPT_BOOLEAN('I', "show-info", &show_full_info,
"display extended information from perf.data file"), "display extended information from perf.data file"),
OPT_BOOLEAN('\0', "show-kernel-path", &symbol_conf.show_kernel_path, OPT_BOOLEAN('\0', "show-kernel-path", &symbol_conf.show_kernel_path,
......
...@@ -15,6 +15,7 @@ ...@@ -15,6 +15,7 @@
#include "machine.h" #include "machine.h"
#include "symbol.h" #include "symbol.h"
#include "strlist.h" #include "strlist.h"
#include "intlist.h"
#include "header.h" #include "header.h"
#include <elf.h> #include <elf.h>
...@@ -1859,6 +1860,20 @@ int setup_list(struct strlist **list, const char *list_str, ...@@ -1859,6 +1860,20 @@ int setup_list(struct strlist **list, const char *list_str,
return 0; return 0;
} }
int setup_intlist(struct intlist **list, const char *list_str,
const char *list_name)
{
if (list_str == NULL)
return 0;
*list = intlist__new(list_str);
if (!*list) {
pr_err("problems parsing %s list\n", list_name);
return -1;
}
return 0;
}
static bool symbol__read_kptr_restrict(void) static bool symbol__read_kptr_restrict(void)
{ {
bool value = false; bool value = false;
...@@ -1909,9 +1924,17 @@ int symbol__init(struct perf_session_env *env) ...@@ -1909,9 +1924,17 @@ int symbol__init(struct perf_session_env *env)
symbol_conf.comm_list_str, "comm") < 0) symbol_conf.comm_list_str, "comm") < 0)
goto out_free_dso_list; goto out_free_dso_list;
if (setup_intlist(&symbol_conf.pid_list,
symbol_conf.pid_list_str, "pid") < 0)
goto out_free_comm_list;
if (setup_intlist(&symbol_conf.tid_list,
symbol_conf.tid_list_str, "tid") < 0)
goto out_free_pid_list;
if (setup_list(&symbol_conf.sym_list, if (setup_list(&symbol_conf.sym_list,
symbol_conf.sym_list_str, "symbol") < 0) symbol_conf.sym_list_str, "symbol") < 0)
goto out_free_comm_list; goto out_free_tid_list;
/* /*
* A path to symbols of "/" is identical to "" * A path to symbols of "/" is identical to ""
...@@ -1930,6 +1953,10 @@ int symbol__init(struct perf_session_env *env) ...@@ -1930,6 +1953,10 @@ int symbol__init(struct perf_session_env *env)
symbol_conf.initialized = true; symbol_conf.initialized = true;
return 0; return 0;
out_free_tid_list:
intlist__delete(symbol_conf.tid_list);
out_free_pid_list:
intlist__delete(symbol_conf.pid_list);
out_free_comm_list: out_free_comm_list:
strlist__delete(symbol_conf.comm_list); strlist__delete(symbol_conf.comm_list);
out_free_dso_list: out_free_dso_list:
...@@ -1944,6 +1971,8 @@ void symbol__exit(void) ...@@ -1944,6 +1971,8 @@ void symbol__exit(void)
strlist__delete(symbol_conf.sym_list); strlist__delete(symbol_conf.sym_list);
strlist__delete(symbol_conf.dso_list); strlist__delete(symbol_conf.dso_list);
strlist__delete(symbol_conf.comm_list); strlist__delete(symbol_conf.comm_list);
intlist__delete(symbol_conf.tid_list);
intlist__delete(symbol_conf.pid_list);
vmlinux_path__exit(); vmlinux_path__exit();
symbol_conf.sym_list = symbol_conf.dso_list = symbol_conf.comm_list = NULL; symbol_conf.sym_list = symbol_conf.dso_list = symbol_conf.comm_list = NULL;
symbol_conf.initialized = false; symbol_conf.initialized = false;
......
...@@ -78,6 +78,7 @@ static inline size_t symbol__size(const struct symbol *sym) ...@@ -78,6 +78,7 @@ static inline size_t symbol__size(const struct symbol *sym)
} }
struct strlist; struct strlist;
struct intlist;
struct symbol_conf { struct symbol_conf {
unsigned short priv_size; unsigned short priv_size;
...@@ -115,6 +116,8 @@ struct symbol_conf { ...@@ -115,6 +116,8 @@ struct symbol_conf {
const char *guestmount; const char *guestmount;
const char *dso_list_str, const char *dso_list_str,
*comm_list_str, *comm_list_str,
*pid_list_str,
*tid_list_str,
*sym_list_str, *sym_list_str,
*col_width_list_str; *col_width_list_str;
struct strlist *dso_list, struct strlist *dso_list,
...@@ -124,6 +127,8 @@ struct symbol_conf { ...@@ -124,6 +127,8 @@ struct symbol_conf {
*dso_to_list, *dso_to_list,
*sym_from_list, *sym_from_list,
*sym_to_list; *sym_to_list;
struct intlist *pid_list,
*tid_list;
const char *symfs; const char *symfs;
}; };
...@@ -295,5 +300,7 @@ int compare_proc_modules(const char *from, const char *to); ...@@ -295,5 +300,7 @@ int compare_proc_modules(const char *from, const char *to);
int setup_list(struct strlist **list, const char *list_str, int setup_list(struct strlist **list, const char *list_str,
const char *list_name); const char *list_name);
int setup_intlist(struct intlist **list, const char *list_str,
const char *list_name);
#endif /* __PERF_SYMBOL */ #endif /* __PERF_SYMBOL */
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
#include <sys/types.h> #include <sys/types.h>
#include "symbol.h" #include "symbol.h"
#include <strlist.h> #include <strlist.h>
#include <intlist.h>
struct thread_stack; struct thread_stack;
...@@ -100,6 +101,16 @@ static inline bool thread__is_filtered(struct thread *thread) ...@@ -100,6 +101,16 @@ static inline bool thread__is_filtered(struct thread *thread)
return true; return true;
} }
if (symbol_conf.pid_list &&
!intlist__has_entry(symbol_conf.pid_list, thread->pid_)) {
return true;
}
if (symbol_conf.tid_list &&
!intlist__has_entry(symbol_conf.tid_list, thread->tid)) {
return true;
}
return false; return false;
} }
......
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