Commit d3afd28c authored by Athira Rajeev's avatar Athira Rajeev Committed by Michael Ellerman

powerpc/perf: Fix to update radix_scope_qual in power10

power10 uses bit 9 of the raw event code as RADIX_SCOPE_QUAL.
This bit is used for enabling the radix process events.
Patch fixes the PMU counter support functions to program bit
18 of MMCR1 ( Monitor Mode Control Register1 ) with the
RADIX_SCOPE_QUAL bit value. Since this field is not per-pmc,
add this to PMU group constraints to make sure events in a
group will have same bit value for this field. Use bit 21 as
constraint bit field for radix_scope_qual. Patch also updates
the power10 raw event encoding layout information, format field
and constraints bit layout to include the radix_scope_qual bit.

Fixes: a64e697c ("powerpc/perf: power10 Performance Monitoring support")
Signed-off-by: default avatarAthira Rajeev <atrajeev@linux.vnet.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/1606409684-1589-2-git-send-email-atrajeev@linux.vnet.ibm.com
parent ec0f9b98
...@@ -339,6 +339,11 @@ int isa207_get_constraint(u64 event, unsigned long *maskp, unsigned long *valp) ...@@ -339,6 +339,11 @@ int isa207_get_constraint(u64 event, unsigned long *maskp, unsigned long *valp)
value |= CNST_L1_QUAL_VAL(cache); value |= CNST_L1_QUAL_VAL(cache);
} }
if (cpu_has_feature(CPU_FTR_ARCH_31)) {
mask |= CNST_RADIX_SCOPE_GROUP_MASK;
value |= CNST_RADIX_SCOPE_GROUP_VAL(event >> p10_EVENT_RADIX_SCOPE_QUAL_SHIFT);
}
if (is_event_marked(event)) { if (is_event_marked(event)) {
mask |= CNST_SAMPLE_MASK; mask |= CNST_SAMPLE_MASK;
value |= CNST_SAMPLE_VAL(event >> EVENT_SAMPLE_SHIFT); value |= CNST_SAMPLE_VAL(event >> EVENT_SAMPLE_SHIFT);
...@@ -456,6 +461,13 @@ int isa207_compute_mmcr(u64 event[], int n_ev, ...@@ -456,6 +461,13 @@ int isa207_compute_mmcr(u64 event[], int n_ev,
} }
} }
/* Set RADIX_SCOPE_QUAL bit */
if (cpu_has_feature(CPU_FTR_ARCH_31)) {
val = (event[i] >> p10_EVENT_RADIX_SCOPE_QUAL_SHIFT) &
p10_EVENT_RADIX_SCOPE_QUAL_MASK;
mmcr1 |= val << p10_MMCR1_RADIX_SCOPE_QUAL_SHIFT;
}
if (is_event_marked(event[i])) { if (is_event_marked(event[i])) {
mmcra |= MMCRA_SAMPLE_ENABLE; mmcra |= MMCRA_SAMPLE_ENABLE;
......
...@@ -101,6 +101,9 @@ ...@@ -101,6 +101,9 @@
#define p10_EVENT_CACHE_SEL_MASK 0x3ull #define p10_EVENT_CACHE_SEL_MASK 0x3ull
#define p10_EVENT_MMCR3_MASK 0x7fffull #define p10_EVENT_MMCR3_MASK 0x7fffull
#define p10_EVENT_MMCR3_SHIFT 45 #define p10_EVENT_MMCR3_SHIFT 45
#define p10_EVENT_RADIX_SCOPE_QUAL_SHIFT 9
#define p10_EVENT_RADIX_SCOPE_QUAL_MASK 0x1
#define p10_MMCR1_RADIX_SCOPE_QUAL_SHIFT 45
#define p10_EVENT_VALID_MASK \ #define p10_EVENT_VALID_MASK \
((p10_SDAR_MODE_MASK << p10_SDAR_MODE_SHIFT | \ ((p10_SDAR_MODE_MASK << p10_SDAR_MODE_SHIFT | \
...@@ -112,6 +115,7 @@ ...@@ -112,6 +115,7 @@
(p9_EVENT_COMBINE_MASK << p9_EVENT_COMBINE_SHIFT) | \ (p9_EVENT_COMBINE_MASK << p9_EVENT_COMBINE_SHIFT) | \
(p10_EVENT_MMCR3_MASK << p10_EVENT_MMCR3_SHIFT) | \ (p10_EVENT_MMCR3_MASK << p10_EVENT_MMCR3_SHIFT) | \
(EVENT_MARKED_MASK << EVENT_MARKED_SHIFT) | \ (EVENT_MARKED_MASK << EVENT_MARKED_SHIFT) | \
(p10_EVENT_RADIX_SCOPE_QUAL_MASK << p10_EVENT_RADIX_SCOPE_QUAL_SHIFT) | \
EVENT_LINUX_MASK | \ EVENT_LINUX_MASK | \
EVENT_PSEL_MASK)) EVENT_PSEL_MASK))
/* /*
...@@ -125,9 +129,9 @@ ...@@ -125,9 +129,9 @@
* *
* 28 24 20 16 12 8 4 0 * 28 24 20 16 12 8 4 0
* | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | * | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - |
* [ ] | [ ] [ sample ] [ ] [6] [5] [4] [3] [2] [1] * [ ] | [ ] | [ sample ] [ ] [6] [5] [4] [3] [2] [1]
* | | | | * | | | | |
* BHRB IFM -* | | | Count of events for each PMC. * BHRB IFM -* | | |*radix_scope | Count of events for each PMC.
* EBB -* | | p1, p2, p3, p4, p5, p6. * EBB -* | | p1, p2, p3, p4, p5, p6.
* L1 I/D qualifier -* | * L1 I/D qualifier -* |
* nc - number of counters -* * nc - number of counters -*
...@@ -165,6 +169,9 @@ ...@@ -165,6 +169,9 @@
#define CNST_L2L3_GROUP_VAL(v) (((v) & 0x1full) << 55) #define CNST_L2L3_GROUP_VAL(v) (((v) & 0x1full) << 55)
#define CNST_L2L3_GROUP_MASK CNST_L2L3_GROUP_VAL(0x1f) #define CNST_L2L3_GROUP_MASK CNST_L2L3_GROUP_VAL(0x1f)
#define CNST_RADIX_SCOPE_GROUP_VAL(v) (((v) & 0x1ull) << 21)
#define CNST_RADIX_SCOPE_GROUP_MASK CNST_RADIX_SCOPE_GROUP_VAL(1)
/* /*
* For NC we are counting up to 4 events. This requires three bits, and we need * For NC we are counting up to 4 events. This requires three bits, and we need
* the fifth event to overflow and set the 4th bit. To achieve that we bias the * the fifth event to overflow and set the 4th bit. To achieve that we bias the
......
...@@ -23,10 +23,10 @@ ...@@ -23,10 +23,10 @@
* *
* 28 24 20 16 12 8 4 0 * 28 24 20 16 12 8 4 0
* | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | * | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - | - - - - |
* [ ] [ sample ] [ ] [ ] [ pmc ] [unit ] [ ] m [ pmcxsel ] * [ ] [ sample ] [ ] [ ] [ pmc ] [unit ] [ ] | m [ pmcxsel ]
* | | | | | | * | | | | | | |
* | | | | | *- mark * | | | | | | *- mark
* | | | *- L1/L2/L3 cache_sel | * | | | *- L1/L2/L3 cache_sel | |*-radix_scope_qual
* | | sdar_mode | * | | sdar_mode |
* | *- sampling mode for marked events *- combine * | *- sampling mode for marked events *- combine
* | * |
...@@ -59,6 +59,7 @@ ...@@ -59,6 +59,7 @@
* *
* MMCR1[16] = cache_sel[0] * MMCR1[16] = cache_sel[0]
* MMCR1[17] = cache_sel[1] * MMCR1[17] = cache_sel[1]
* MMCR1[18] = radix_scope_qual
* *
* if mark: * if mark:
* MMCRA[63] = 1 (SAMPLE_ENABLE) * MMCRA[63] = 1 (SAMPLE_ENABLE)
...@@ -175,6 +176,7 @@ PMU_FORMAT_ATTR(src_sel, "config:45-46"); ...@@ -175,6 +176,7 @@ PMU_FORMAT_ATTR(src_sel, "config:45-46");
PMU_FORMAT_ATTR(invert_bit, "config:47"); PMU_FORMAT_ATTR(invert_bit, "config:47");
PMU_FORMAT_ATTR(src_mask, "config:48-53"); PMU_FORMAT_ATTR(src_mask, "config:48-53");
PMU_FORMAT_ATTR(src_match, "config:54-59"); PMU_FORMAT_ATTR(src_match, "config:54-59");
PMU_FORMAT_ATTR(radix_scope, "config:9");
static struct attribute *power10_pmu_format_attr[] = { static struct attribute *power10_pmu_format_attr[] = {
&format_attr_event.attr, &format_attr_event.attr,
...@@ -194,6 +196,7 @@ static struct attribute *power10_pmu_format_attr[] = { ...@@ -194,6 +196,7 @@ static struct attribute *power10_pmu_format_attr[] = {
&format_attr_invert_bit.attr, &format_attr_invert_bit.attr,
&format_attr_src_mask.attr, &format_attr_src_mask.attr,
&format_attr_src_match.attr, &format_attr_src_match.attr,
&format_attr_radix_scope.attr,
NULL, NULL,
}; };
......
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