summaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorRob Herring <robh@kernel.org>2021-12-08 14:11:21 -0600
committerWill Deacon <will@kernel.org>2021-12-14 11:30:54 +0000
commit82ff0c022d19c2ad69a472692bb7ee01ac07a40b (patch)
tree6f79c14d0e5c230e03ec3b97481982de4466d974 /include
parent369461ce8fb6c8156206c7110d7da48e9fbc41bb (diff)
downloadlinux-stable-82ff0c022d19c2ad69a472692bb7ee01ac07a40b.tar.gz
linux-stable-82ff0c022d19c2ad69a472692bb7ee01ac07a40b.tar.bz2
linux-stable-82ff0c022d19c2ad69a472692bb7ee01ac07a40b.zip
perf: Add a counter for number of user access events in context
On arm64, user space counter access will be controlled differently compared to x86. On x86, access in the strictest mode is enabled for all tasks in an MM when any event is mmap'ed. For arm64, access is explicitly requested for an event and only enabled when the event's context is active. This avoids hooks into the arch context switch code and gives better control of when access is enabled. In order to configure user space access when the PMU is enabled, it is necessary to know if any event (currently active or not) in the current context has user space accessed enabled. Add a counter similar to other counters in the context to avoid walking the event list every time. Reviewed-by: Mark Rutland <mark.rutland@arm.com> Reviewed-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Rob Herring <robh@kernel.org> Link: https://lore.kernel.org/r/20211208201124.310740-3-robh@kernel.org Signed-off-by: Will Deacon <will@kernel.org>
Diffstat (limited to 'include')
-rw-r--r--include/linux/perf_event.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/include/linux/perf_event.h b/include/linux/perf_event.h
index ba9467972c09..411e34210fbf 100644
--- a/include/linux/perf_event.h
+++ b/include/linux/perf_event.h
@@ -831,6 +831,7 @@ struct perf_event_context {
int nr_events;
int nr_active;
+ int nr_user;
int is_active;
int nr_stat;
int nr_freq;