diff options
Diffstat (limited to 'tools/perf/builtin-script.c')
| -rw-r--r-- | tools/perf/builtin-script.c | 25 | 
1 files changed, 19 insertions, 6 deletions
diff --git a/tools/perf/builtin-script.c b/tools/perf/builtin-script.c index 48588ccf902e..edacfa98d073 100644 --- a/tools/perf/builtin-script.c +++ b/tools/perf/builtin-script.c @@ -30,6 +30,7 @@  #include "util/thread-stack.h"  #include "util/time-utils.h"  #include "util/path.h" +#include "util/event.h"  #include "ui/ui.h"  #include "print_binary.h"  #include "archinsn.h" @@ -115,6 +116,7 @@ enum perf_output_field {  	PERF_OUTPUT_SRCCODE	    = 1ULL << 30,  	PERF_OUTPUT_IPC             = 1ULL << 31,  	PERF_OUTPUT_TOD             = 1ULL << 32, +	PERF_OUTPUT_DATA_PAGE_SIZE  = 1ULL << 33,  };  struct perf_script { @@ -179,6 +181,7 @@ struct output_option {  	{.str = "srccode", .field = PERF_OUTPUT_SRCCODE},  	{.str = "ipc", .field = PERF_OUTPUT_IPC},  	{.str = "tod", .field = PERF_OUTPUT_TOD}, +	{.str = "data_page_size", .field = PERF_OUTPUT_DATA_PAGE_SIZE},  };  enum { @@ -251,7 +254,8 @@ static struct {  			      PERF_OUTPUT_SYM | PERF_OUTPUT_SYMOFFSET |  			      PERF_OUTPUT_DSO | PERF_OUTPUT_PERIOD |  			      PERF_OUTPUT_ADDR | PERF_OUTPUT_DATA_SRC | -			      PERF_OUTPUT_WEIGHT | PERF_OUTPUT_PHYS_ADDR, +			      PERF_OUTPUT_WEIGHT | PERF_OUTPUT_PHYS_ADDR | +			      PERF_OUTPUT_DATA_PAGE_SIZE,  		.invalid_fields = PERF_OUTPUT_TRACE | PERF_OUTPUT_BPF_OUTPUT,  	}, @@ -499,6 +503,10 @@ static int evsel__check_attr(struct evsel *evsel, struct perf_session *session)  	    evsel__check_stype(evsel, PERF_SAMPLE_PHYS_ADDR, "PHYS_ADDR", PERF_OUTPUT_PHYS_ADDR))  		return -EINVAL; +	if (PRINT_FIELD(DATA_PAGE_SIZE) && +	    evsel__check_stype(evsel, PERF_SAMPLE_DATA_PAGE_SIZE, "DATA_PAGE_SIZE", PERF_OUTPUT_DATA_PAGE_SIZE)) +		return -EINVAL; +  	return 0;  } @@ -1847,7 +1855,7 @@ static void perf_sample__fprint_metric(struct perf_script *script,  	u64 val;  	if (!evsel->stats) -		perf_evlist__alloc_stats(script->session->evlist, false); +		evlist__alloc_stats(script->session->evlist, false);  	if (evsel_script(evsel->leader)->gnum++ == 0)  		perf_stat__reset_shadow_stats();  	val = sample->period * evsel->scale; @@ -1920,6 +1928,7 @@ static void process_event(struct perf_script *script,  	unsigned int type = output_type(attr->type);  	struct evsel_script *es = evsel->priv;  	FILE *fp = es->fp; +	char str[PAGE_SIZE_NAME_LEN];  	if (output[type].fields == 0)  		return; @@ -2008,6 +2017,9 @@ static void process_event(struct perf_script *script,  	if (PRINT_FIELD(PHYS_ADDR))  		fprintf(fp, "%16" PRIx64, sample->phys_addr); +	if (PRINT_FIELD(DATA_PAGE_SIZE)) +		fprintf(fp, " %s", get_page_size_name(sample->data_page_size, str)); +  	perf_sample__fprintf_ipc(sample, attr, fp);  	fprintf(fp, "\n"); @@ -2224,7 +2236,7 @@ static int print_event_with_time(struct perf_tool *tool,  {  	struct perf_script *script = container_of(tool, struct perf_script, tool);  	struct perf_session *session = script->session; -	struct evsel *evsel = perf_evlist__id2evsel(session->evlist, sample->id); +	struct evsel *evsel = evlist__id2evsel(session->evlist, sample->id);  	struct thread *thread = NULL;  	if (evsel && !evsel->core.attr.sample_id_all) { @@ -3308,7 +3320,7 @@ static int set_maps(struct perf_script *script)  	perf_evlist__set_maps(&evlist->core, script->cpus, script->threads); -	if (perf_evlist__alloc_stats(evlist, true)) +	if (evlist__alloc_stats(evlist, true))  		return -ENOMEM;  	script->allocated = true; @@ -3506,7 +3518,8 @@ int cmd_script(int argc, const char **argv)  		     "Fields: comm,tid,pid,time,cpu,event,trace,ip,sym,dso,"  		     "addr,symoff,srcline,period,iregs,uregs,brstack,"  		     "brstacksym,flags,bpf-output,brstackinsn,brstackoff," -		     "callindent,insn,insnlen,synth,phys_addr,metric,misc,ipc,tod", +		     "callindent,insn,insnlen,synth,phys_addr,metric,misc,ipc,tod," +		     "data_page_size",  		     parse_output_fields),  	OPT_BOOLEAN('a', "all-cpus", &system_wide,  		    "system-wide collection from all CPUs"), @@ -3935,7 +3948,7 @@ out_delete:  		zfree(&script.ptime_range);  	} -	perf_evlist__free_stats(session->evlist); +	evlist__free_stats(session->evlist);  	perf_session__delete(session);  	if (script_started)  | 
