Commit 03d9fcb7 authored by Jiri Olsa's avatar Jiri Olsa Committed by Arnaldo Carvalho de Melo

perf c2c report: Add cacheline address count column

Adding the 'PA cnt' column grouped under data cacheline address.

It shows how many times the physical addresses changed for the hist
entry. It does not show the number of different physical addresses for
entry, because we don't store those. We only track the number of times
we got different address than we currently hold, which is not expensive
and gives similar info.

  $ perf c2c report --stdio

  #        ----------- Cacheline ----------    Total      Tot  ----- LLC Load Hitm -----
  # Index             Address  Node  PA cnt  records     Hitm    Total      Lcl      Rmt
  # .....  ..................  ....  ......  .......  .......  .......  .......  .......
  #
        0  0xffff9ad56dca0a80     0       9       10    7.69%        2        2        0
        1  0xffff9ad56dce0a80     0       9        9    7.69%        2        2        0
        2  0xffff9ad37659ad80     0       1        2    3.85%        1        1        0

  ...

  #        ----- HITM -----  -- Store Refs --  --------- Data address ---------
  #   Num      Rmt      Lcl   L1 Hit  L1 Miss              Offset  Node  PA cnt      Pid
  # .....  .......  .......  .......  .......  ..................  ....  ......  .......
  #
    -------------------------------------------------------------
        0        0        2        3        0  0xffff9ad56dca0a80
    -------------------------------------------------------------
             0.00%    0.00%   33.33%    0.00%                 0x0     0       1     2510
             0.00%    0.00%   33.33%    0.00%                 0x4     0       1     2476
             0.00%    0.00%   33.33%    0.00%                0x20     0       1        0
             0.00%  100.00%    0.00%    0.00%                0x38     0       1        0
Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Joe Mario <jmario@redhat.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/20180309101442.9224-10-jolsa@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent d0802b1e
...@@ -507,6 +507,17 @@ dcacheline_node_entry(struct perf_hpp_fmt *fmt, struct perf_hpp *hpp, ...@@ -507,6 +507,17 @@ dcacheline_node_entry(struct perf_hpp_fmt *fmt, struct perf_hpp *hpp,
return scnprintf(hpp->buf, hpp->size, "%*s", width, c2c_he->nodestr); return scnprintf(hpp->buf, hpp->size, "%*s", width, c2c_he->nodestr);
} }
static int
dcacheline_node_count(struct perf_hpp_fmt *fmt, struct perf_hpp *hpp,
struct hist_entry *he)
{
struct c2c_hist_entry *c2c_he;
int width = c2c_width(fmt, hpp, he->hists);
c2c_he = container_of(he, struct c2c_hist_entry, he);
return scnprintf(hpp->buf, hpp->size, "%*lu", width, c2c_he->paddr_cnt);
}
static int offset_entry(struct perf_hpp_fmt *fmt, struct perf_hpp *hpp, static int offset_entry(struct perf_hpp_fmt *fmt, struct perf_hpp *hpp,
struct hist_entry *he) struct hist_entry *he)
{ {
...@@ -1252,7 +1263,7 @@ cl_idx_empty_entry(struct perf_hpp_fmt *fmt, struct perf_hpp *hpp, ...@@ -1252,7 +1263,7 @@ cl_idx_empty_entry(struct perf_hpp_fmt *fmt, struct perf_hpp *hpp,
} }
static struct c2c_dimension dim_dcacheline = { static struct c2c_dimension dim_dcacheline = {
.header = HEADER_SPAN("--- Cacheline ----", "Address", 1), .header = HEADER_SPAN("--- Cacheline ----", "Address", 2),
.name = "dcacheline", .name = "dcacheline",
.cmp = dcacheline_cmp, .cmp = dcacheline_cmp,
.entry = dcacheline_entry, .entry = dcacheline_entry,
...@@ -1267,10 +1278,18 @@ static struct c2c_dimension dim_dcacheline_node = { ...@@ -1267,10 +1278,18 @@ static struct c2c_dimension dim_dcacheline_node = {
.width = 4, .width = 4,
}; };
static struct c2c_header header_offset_tui = HEADER_SPAN("-----", "Off", 1); static struct c2c_dimension dim_dcacheline_count = {
.header = HEADER_LOW("PA cnt"),
.name = "dcacheline_count",
.cmp = empty_cmp,
.entry = dcacheline_node_count,
.width = 6,
};
static struct c2c_header header_offset_tui = HEADER_SPAN("-----", "Off", 2);
static struct c2c_dimension dim_offset = { static struct c2c_dimension dim_offset = {
.header = HEADER_SPAN("--- Data address -", "Offset", 1), .header = HEADER_SPAN("--- Data address -", "Offset", 2),
.name = "offset", .name = "offset",
.cmp = offset_cmp, .cmp = offset_cmp,
.entry = offset_entry, .entry = offset_entry,
...@@ -1605,6 +1624,7 @@ static struct c2c_dimension dim_dcacheline_num_empty = { ...@@ -1605,6 +1624,7 @@ static struct c2c_dimension dim_dcacheline_num_empty = {
static struct c2c_dimension *dimensions[] = { static struct c2c_dimension *dimensions[] = {
&dim_dcacheline, &dim_dcacheline,
&dim_dcacheline_node, &dim_dcacheline_node,
&dim_dcacheline_count,
&dim_offset, &dim_offset,
&dim_offset_node, &dim_offset_node,
&dim_iaddr, &dim_iaddr,
...@@ -2496,7 +2516,8 @@ static int ui_quirks(void) ...@@ -2496,7 +2516,8 @@ static int ui_quirks(void)
/* Fix the zero line for dcacheline column. */ /* Fix the zero line for dcacheline column. */
buf = fill_line("Cacheline", dim_dcacheline.width + buf = fill_line("Cacheline", dim_dcacheline.width +
dim_dcacheline_node.width + 2); dim_dcacheline_node.width +
dim_dcacheline_count.width + 4);
if (!buf) if (!buf)
return -ENOMEM; return -ENOMEM;
...@@ -2504,7 +2525,8 @@ static int ui_quirks(void) ...@@ -2504,7 +2525,8 @@ static int ui_quirks(void)
/* Fix the zero line for offset column. */ /* Fix the zero line for offset column. */
buf = fill_line(nodestr, dim_offset.width + buf = fill_line(nodestr, dim_offset.width +
dim_offset_node.width + 2); dim_offset_node.width +
dim_dcacheline_count.width + 4);
if (!buf) if (!buf)
return -ENOMEM; return -ENOMEM;
...@@ -2626,7 +2648,7 @@ static int build_cl_output(char *cl_sort, bool no_source) ...@@ -2626,7 +2648,7 @@ static int build_cl_output(char *cl_sort, bool no_source)
"percent_lcl_hitm," "percent_lcl_hitm,"
"percent_stores_l1hit," "percent_stores_l1hit,"
"percent_stores_l1miss," "percent_stores_l1miss,"
"offset,offset_node,", "offset,offset_node,dcacheline_count,",
add_pid ? "pid," : "", add_pid ? "pid," : "",
add_tid ? "tid," : "", add_tid ? "tid," : "",
add_iaddr ? "iaddr," : "", add_iaddr ? "iaddr," : "",
...@@ -2789,6 +2811,7 @@ static int perf_c2c__report(int argc, const char **argv) ...@@ -2789,6 +2811,7 @@ static int perf_c2c__report(int argc, const char **argv)
"cl_idx," "cl_idx,"
"dcacheline," "dcacheline,"
"dcacheline_node," "dcacheline_node,"
"dcacheline_count,"
"tot_recs," "tot_recs,"
"percent_hitm," "percent_hitm,"
"tot_hitm,lcl_hitm,rmt_hitm," "tot_hitm,lcl_hitm,rmt_hitm,"
......
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