All of lore.kernel.org
 help / color / mirror / Atom feed
From: Namhyung Kim <namhyung@gmail.com>
To: Don Zickus <dzickus@redhat.com>
Cc: acme@ghostprotocols.net, LKML <linux-kernel@vger.kernel.org>,
	jolsa@redhat.com, jmario@redhat.com, fowles@inreach.com,
	peterz@infradead.org, eranian@google.com, andi.kleen@intel.com,
	Arnaldo Carvalho de Melo <acme@redhat.com>,
	David Ahern <dsahern@gmail.com>,
	Frederic Weisbecker <fweisbec@gmail.com>,
	Mike Galbraith <efault@gmx.de>, Paul Mackerras <paulus@samba.org>,
	Richard Fowles <rfowles@redhat.com>
Subject: Re: [PATCH 04/15 V3] perf c2c: Dump raw records, decode data_src bits
Date: Tue, 08 Apr 2014 16:09:03 +0900	[thread overview]
Message-ID: <8761mkxpps.fsf@sejong.aot.lge.com> (raw)
In-Reply-To: <1395689826-215033-5-git-send-email-dzickus@redhat.com> (Don Zickus's message of "Mon, 24 Mar 2014 15:36:55 -0400")

On Mon, 24 Mar 2014 15:36:55 -0400, Don Zickus wrote:
> +	union perf_mem_data_src dsrc = { .val = val, };
> +	int printed = scnprintf(bf, size, PREFIX);
> +	size_t i;
> +	bool first_present = true;
> +
> +	for (i = 0; i < ARRAY_SIZE(decode_bits); i++) {
> +		int bitval;
> +
> +		switch (decode_bits[i].field) {
> +		case OP:  bitval = decode_bits[i].bit & dsrc.mem_op;    break;
> +		case LVL: bitval = decode_bits[i].bit & dsrc.mem_lvl;   break;
> +		case SNP: bitval = decode_bits[i].bit & dsrc.mem_snoop; break;
> +		case LCK: bitval = decode_bits[i].bit & dsrc.mem_lock;  break;
> +		case TLB: bitval = decode_bits[i].bit & dsrc.mem_dtlb;  break;
> +		default: bitval = 0;					break;
> +		}
> +
> +		if (!bitval)
> +			continue;
> +
> +		if (strlen(decode_bits[i].name) + !!i > size - printed - sizeof(SUFFIX)) {
> +			sprintf(bf + size - sizeof(SUFFIX) - sizeof(ELLIPSIS) + 1, ELLIPSIS);
> +			printed = size - sizeof(SUFFIX);
> +			break;
> +		}
> +
> +		printed += scnprintf(bf + printed, size - printed, "%s%s",
> +				     first_present ? "" : ",", decode_bits[i].name);
> +		first_present = false;
> +	}
> +
> +	printed += scnprintf(bf + printed, size - printed, SUFFIX);

It seems that adjusting bf and size as printed might make the code
somewhat simpler and readable - i.e.:

        ret = scnprintf(bf, size, "%s", ...);

        bf += ret;
        size -= ret;
        printed += ret;


> +	return printed;
>  }
>  
> -static int perf_c2c__process_load(struct perf_evsel *evsel,
> -				  struct perf_sample *sample,
> -				  struct addr_location *al)
> +static int perf_c2c__fprintf_header(FILE *fp)
>  {
> -	perf_sample__fprintf(sample, evsel, al, stdout);
> -	return 0;
> +	int printed = fprintf(fp, "%c %-16s  %6s  %6s  %4s  %18s  %18s  %18s  %6s  %-10s %-60s %s\n", 
> +			      'T',
> +			      "Status",
> +			      "Pid",
> +			      "Tid",
> +			      "CPU",
> +			      "Inst Adrs",
> +			      "Virt Data Adrs",
> +			      "Phys Data Adrs",
> +			      "Cycles",
> +			      "Source",
> +			      "  Decoded Source",
> +			      "ObJect:Symbol");

s/ObJect/Object/ ?

Thanks,
Namhyung


> +	return printed + fprintf(fp, "%-*.*s\n", printed, printed, graph_dotted_line);
> +}

  reply	other threads:[~2014-04-08  7:09 UTC|newest]

Thread overview: 45+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-03-24 19:36 [PATCH 00/15 V3] perf, c2c: Add new tool to analyze cacheline contention on NUMA systems Don Zickus
2014-03-24 19:36 ` [PATCH 01/15 V3] perf: Fix stddev calculation Don Zickus
2014-03-24 19:36 ` [PATCH 02/15 V3] perf, callchain: Add generic callchain print handler for stdio Don Zickus
2014-03-24 19:36 ` [PATCH 03/15 V3] perf c2c: Shared data analyser Don Zickus
2014-04-08  6:59   ` Namhyung Kim
2014-04-08 14:22     ` Don Zickus
2014-04-09  0:58       ` Namhyung Kim
2014-04-09  1:29         ` Andi Kleen
2014-04-08 14:23     ` Don Zickus
2014-03-24 19:36 ` [PATCH 04/15 V3] perf c2c: Dump raw records, decode data_src bits Don Zickus
2014-04-08  7:09   ` Namhyung Kim [this message]
2014-03-24 19:36 ` [PATCH 05/15 V3] perf, c2c: Rework setup code to prepare for features Don Zickus
2014-03-29 17:10   ` Jiri Olsa
2014-04-01  2:52     ` Don Zickus
2014-04-08  7:41     ` Namhyung Kim
2014-04-08 14:11       ` Don Zickus
2014-04-09  1:12         ` Namhyung Kim
2014-04-09  1:36           ` Don Zickus
2014-04-11 14:57             ` Jiri Olsa
2014-04-08  7:18   ` Namhyung Kim
2014-03-24 19:36 ` [PATCH 06/15 V3] perf, c2c: Add in new options to configure latency and stores Don Zickus
2014-03-29 17:11   ` Jiri Olsa
2014-04-01  2:55     ` Don Zickus
2014-04-06 13:14       ` Jiri Olsa
2014-04-07 18:16         ` Don Zickus
2014-04-09  0:17           ` Namhyung Kim
2014-04-08  7:37         ` Namhyung Kim
2014-04-08  7:31   ` Namhyung Kim
2014-03-24 19:36 ` [PATCH 07/15 V3] perf, c2c: Add in sort on physid Don Zickus
2014-04-08  7:56   ` Namhyung Kim
2014-04-08 14:17     ` Don Zickus
2014-04-09  1:30       ` Namhyung Kim
2014-04-09  1:56         ` Don Zickus
2014-03-24 19:36 ` [PATCH 08/15 V3] perf, c2c: Add stats to track data source bits and cpu to node maps Don Zickus
2014-04-08  8:05   ` Namhyung Kim
2014-03-24 19:37 ` [PATCH 09/15 V3] perf, c2c: Sort based on hottest cache line Don Zickus
2014-04-08  8:23   ` Namhyung Kim
2014-03-24 19:37 ` [PATCH 10/15 V3] perf, c2c: Display cacheline HITM analysis to stdout Don Zickus
2014-04-08  8:26   ` Namhyung Kim
2014-04-08 23:46   ` Namhyung Kim
2014-03-24 19:37 ` [PATCH 11/15 V3] perf, c2c: Add callchain support Don Zickus
2014-03-24 19:37 ` [PATCH 12/15 V3] perf, c2c: Output summary stats Don Zickus
2014-03-24 19:37 ` [PATCH 13/15 V3] perf, c2c: Dump rbtree for debugging Don Zickus
2014-03-24 19:37 ` [PATCH 14/15 V3] perf, c2c: Add symbol count table Don Zickus
2014-03-24 19:37 ` [PATCH 15/15 V3] perf, c2c: Add shared cachline summary table Don Zickus

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=8761mkxpps.fsf@sejong.aot.lge.com \
    --to=namhyung@gmail.com \
    --cc=acme@ghostprotocols.net \
    --cc=acme@redhat.com \
    --cc=andi.kleen@intel.com \
    --cc=dsahern@gmail.com \
    --cc=dzickus@redhat.com \
    --cc=efault@gmx.de \
    --cc=eranian@google.com \
    --cc=fowles@inreach.com \
    --cc=fweisbec@gmail.com \
    --cc=jmario@redhat.com \
    --cc=jolsa@redhat.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=paulus@samba.org \
    --cc=peterz@infradead.org \
    --cc=rfowles@redhat.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.