1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
/* SPDX-License-Identifier: Apache-2.0
* Copyright(c) 2022 Cisco Systems, Inc.
*/
#include <vppinfra/format.h>
#include <vppinfra/error.h>
#include <vppinfra/perfmon/perfmon.h>
static u8 *
format_perfmon_bundle_default (u8 *s, va_list *args)
{
clib_perfmon_ctx_t *ctx = va_arg (*args, clib_perfmon_ctx_t *);
clib_perfmon_capture_t *c = va_arg (*args, clib_perfmon_capture_t *);
u32 col = va_arg (*args, int);
u64 *d = c->data;
switch (col)
{
case 0:
if (ctx->ref_clock > 0)
return format (s, "%8.1f", (f64) d[0] / d[1] * (ctx->ref_clock / 1e9));
else
return s;
case 1:
return format (s, "%5.2f", (f64) d[2] / d[0]);
case 2:
if (c->n_ops > 1)
return format (s, "%8.2f", (f64) d[0] / c->n_ops);
else
return format (s, "%8u", d[0]);
case 3:
if (c->n_ops > 1)
return format (s, "%8.2f", (f64) d[2] / c->n_ops);
else
return format (s, "%8u", d[2]);
case 4:
if (c->n_ops > 1)
return format (s, "%9.2f", (f64) d[3] / c->n_ops);
else
return format (s, "%9u", d[3]);
case 5:
if (c->n_ops > 1)
return format (s, "%10.2f", (f64) d[4] / c->n_ops);
else
return format (s, "%10u", d[4]);
default:
return s;
}
}
CLIB_PERFMON_BUNDLE (default) = {
.name = "default",
.desc = "IPC, Clocks/Operatiom, Instr/Operation, Branch Total & Miss",
.type = PERF_TYPE_HARDWARE,
.config[0] = PERF_COUNT_HW_CPU_CYCLES,
.config[1] = PERF_COUNT_HW_REF_CPU_CYCLES,
.config[2] = PERF_COUNT_HW_INSTRUCTIONS,
.config[3] = PERF_COUNT_HW_BRANCH_INSTRUCTIONS,
.config[4] = PERF_COUNT_HW_BRANCH_MISSES,
.n_events = 5,
.format_fn = format_perfmon_bundle_default,
.column_headers = CLIB_STRING_ARRAY ("Freq", "IPC", "Clks/Op", "Inst/Op",
"Brnch/Op", "BrMiss/Op"),
};
|