Commit 82cb9b61 authored by Thomas Richter's avatar Thomas Richter Committed by Heiko Carstens

s390/pai: simplify event start function for perf stat

When an event is started, read the current value of the
PAI counter. This value is saved in event::hw.prev_count.
When an event is stopped, this value is subtracted from the current
value read out at event stop time. The difference is the delta
of this counter.

Simplify the logic and read the event value every time the event is
started. This scheme is identical to other device drivers.
Signed-off-by: default avatarThomas Richter <tmricht@linux.ibm.com>
Acked-by: default avatarSumanth Korikkar <sumanthk@linux.ibm.com>
Signed-off-by: default avatarHeiko Carstens <hca@linux.ibm.com>
parent fe861b0c
...@@ -326,17 +326,9 @@ static void paicrypt_start(struct perf_event *event, int flags) ...@@ -326,17 +326,9 @@ static void paicrypt_start(struct perf_event *event, int flags)
{ {
u64 sum; u64 sum;
/* Event initialization sets last_tag to 0. When later on the events
* are deleted and re-added, do not reset the event count value to zero.
* Events are added, deleted and re-added when 2 or more events
* are active at the same time.
*/
if (!event->attr.sample_period) { /* Counting */ if (!event->attr.sample_period) { /* Counting */
if (!event->hw.last_tag) { sum = paicrypt_getall(event); /* Get current value */
event->hw.last_tag = 1; local64_set(&event->hw.prev_count, sum);
sum = paicrypt_getall(event); /* Get current value */
local64_set(&event->hw.prev_count, sum);
}
} else { /* Sampling */ } else { /* Sampling */
perf_sched_cb_inc(event->pmu); perf_sched_cb_inc(event->pmu);
} }
......
...@@ -331,11 +331,8 @@ static void paiext_start(struct perf_event *event, int flags) ...@@ -331,11 +331,8 @@ static void paiext_start(struct perf_event *event, int flags)
u64 sum; u64 sum;
if (!event->attr.sample_period) { /* Counting */ if (!event->attr.sample_period) { /* Counting */
if (!event->hw.last_tag) { sum = paiext_getall(event); /* Get current value */
event->hw.last_tag = 1; local64_set(&event->hw.prev_count, sum);
sum = paiext_getall(event); /* Get current value */
local64_set(&event->hw.prev_count, sum);
}
} else { /* Sampling */ } else { /* Sampling */
perf_sched_cb_inc(event->pmu); perf_sched_cb_inc(event->pmu);
} }
......
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