public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: "Jin, Yao" <yao.jin@linux.intel.com>
To: Jiri Olsa <jolsa@redhat.com>
Cc: acme@kernel.org, jolsa@kernel.org, peterz@infradead.org,
	mingo@redhat.com, alexander.shishkin@linux.intel.com,
	Linux-kernel@vger.kernel.org, ak@linux.intel.com,
	kan.liang@intel.com, yao.jin@intel.com
Subject: Re: [PATCH v3 1/5] perf util: Cleanup and refactor block info functions
Date: Wed, 23 Oct 2019 20:47:38 +0800	[thread overview]
Message-ID: <abda4105-41ab-7e5e-236e-d048dfe3abed@linux.intel.com> (raw)
In-Reply-To: <20191023113703.GQ22919@krava>



On 10/23/2019 7:37 PM, Jiri Olsa wrote:
> On Tue, Oct 22, 2019 at 04:07:06PM +0800, Jin Yao wrote:
> 
> SNIP
> 
>>   
>> -static int filter_cb(struct hist_entry *he, void *arg __maybe_unused)
>> -{
>> -	/* Skip the calculation of column length in output_resort */
>> -	he->filtered = true;
>> -	return 0;
>> -}
> 
> please move this change into separate patch and explain in changelog
> why this is necessary
> 
> thanks,
> jirka
> 

Got it. I will move this change into a separate patch.

Thanks
Jin Yao

>> -
>>   static void hists__precompute(struct hists *hists)
>>   {
>>   	struct rb_root_cached *root;
>> @@ -792,8 +695,11 @@ static void hists__precompute(struct hists *hists)
>>   		he   = rb_entry(next, struct hist_entry, rb_node_in);
>>   		next = rb_next(&he->rb_node_in);
>>   
>> -		if (compute == COMPUTE_CYCLES)
>> -			process_block_per_sym(he);
>> +		if (compute == COMPUTE_CYCLES) {
>> +			bh = container_of(he, struct block_hist, he);
>> +			init_block_hist(bh);
>> +			block_info__process_sym(he, bh, NULL, 0);
>> +		}
>>   
>>   		data__for_each_file_new(i, d) {
>>   			pair = get_pair_data(he, d);
>> @@ -812,16 +718,18 @@ static void hists__precompute(struct hists *hists)
>>   				compute_wdiff(he, pair);
>>   				break;
>>   			case COMPUTE_CYCLES:
>> -				process_block_per_sym(pair);
>> -				bh = container_of(he, struct block_hist, he);
>>   				pair_bh = container_of(pair, struct block_hist,
>>   						       he);
>> +				init_block_hist(pair_bh);
>> +				block_info__process_sym(pair, pair_bh, NULL, 0);
>> +
>> +				bh = container_of(he, struct block_hist, he);
>>   
>>   				if (bh->valid && pair_bh->valid) {
>>   					block_hists_match(&bh->block_hists,
>>   							  &pair_bh->block_hists);
>> -					hists__output_resort_cb(&pair_bh->block_hists,
>> -								NULL, filter_cb);
>> +					hists__output_resort(&pair_bh->block_hists,
>> +							     NULL);
>>   				}
>>   				break;
>>   			default:
> 
> SNIP
> 
>> diff --git a/tools/perf/util/hist.c b/tools/perf/util/hist.c
>> index 679a1d75090c..a7fa061987e4 100644
>> --- a/tools/perf/util/hist.c
>> +++ b/tools/perf/util/hist.c
>> @@ -18,6 +18,7 @@
>>   #include "srcline.h"
>>   #include "symbol.h"
>>   #include "thread.h"
>> +#include "block-info.h"
>>   #include "ui/progress.h"
>>   #include <errno.h>
>>   #include <math.h>
>> @@ -80,6 +81,8 @@ void hists__calc_col_len(struct hists *hists, struct hist_entry *h)
>>   	int symlen;
>>   	u16 len;
>>   
>> +	if (h->block_info)
>> +		return;
>>   	/*
>>   	 * +4 accounts for '[x] ' priv level info
>>   	 * +2 accounts for 0x prefix on raw addresses
> 
> SNIP
> 

  reply	other threads:[~2019-10-23 12:47 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-10-22  8:07 [PATCH v3 0/5] perf report: Support sorting all blocks by cycles Jin Yao
2019-10-22  8:07 ` [PATCH v3 1/5] perf util: Cleanup and refactor block info functions Jin Yao
2019-10-23 11:37   ` Jiri Olsa
2019-10-23 12:47     ` Jin, Yao [this message]
2019-10-22  8:07 ` [PATCH v3 2/5] perf util: Count the total cycles of all samples Jin Yao
2019-10-22  8:07 ` [PATCH v3 3/5] perf report: Sort by sampled cycles percent per block for stdio Jin Yao
2019-10-23 11:36   ` Jiri Olsa
2019-10-23 13:13     ` Jin, Yao
2019-10-23 11:36   ` Jiri Olsa
2019-10-23 13:11     ` Jin, Yao
2019-10-23 11:36   ` Jiri Olsa
2019-10-23 13:09     ` Jin, Yao
2019-10-23 14:27       ` Jiri Olsa
2019-10-23 14:46         ` Jin, Yao
2019-10-22  8:07 ` [PATCH v3 4/5] perf report: Support --percent-limit for total_cycles Jin Yao
2019-10-22  8:07 ` [PATCH v3 5/5] perf report: Sort by sampled cycles percent per block for tui Jin Yao
2019-10-23 11:36   ` Jiri Olsa
2019-10-23 12:54     ` Jin, Yao

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=abda4105-41ab-7e5e-236e-d048dfe3abed@linux.intel.com \
    --to=yao.jin@linux.intel.com \
    --cc=Linux-kernel@vger.kernel.org \
    --cc=acme@kernel.org \
    --cc=ak@linux.intel.com \
    --cc=alexander.shishkin@linux.intel.com \
    --cc=jolsa@kernel.org \
    --cc=jolsa@redhat.com \
    --cc=kan.liang@intel.com \
    --cc=mingo@redhat.com \
    --cc=peterz@infradead.org \
    --cc=yao.jin@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox