io_uring: ensure finish_wait() is always called in __io_uring_task_cancel()
[linux/fpc-iii.git] / Documentation / arm64 / perf.rst
blobb567f177d3858199036d110392e1e5f7d96c6d42
1 .. SPDX-License-Identifier: GPL-2.0
3 .. _perf_index:
5 =====================
6 Perf Event Attributes
7 =====================
9 :Author: Andrew Murray <andrew.murray@arm.com>
10 :Date: 2019-03-06
12 exclude_user
13 ------------
15 This attribute excludes userspace.
17 Userspace always runs at EL0 and thus this attribute will exclude EL0.
20 exclude_kernel
21 --------------
23 This attribute excludes the kernel.
25 The kernel runs at EL2 with VHE and EL1 without. Guest kernels always run
26 at EL1.
28 For the host this attribute will exclude EL1 and additionally EL2 on a VHE
29 system.
31 For the guest this attribute will exclude EL1. Please note that EL2 is
32 never counted within a guest.
35 exclude_hv
36 ----------
38 This attribute excludes the hypervisor.
40 For a VHE host this attribute is ignored as we consider the host kernel to
41 be the hypervisor.
43 For a non-VHE host this attribute will exclude EL2 as we consider the
44 hypervisor to be any code that runs at EL2 which is predominantly used for
45 guest/host transitions.
47 For the guest this attribute has no effect. Please note that EL2 is
48 never counted within a guest.
51 exclude_host / exclude_guest
52 ----------------------------
54 These attributes exclude the KVM host and guest, respectively.
56 The KVM host may run at EL0 (userspace), EL1 (non-VHE kernel) and EL2 (VHE
57 kernel or non-VHE hypervisor).
59 The KVM guest may run at EL0 (userspace) and EL1 (kernel).
61 Due to the overlapping exception levels between host and guests we cannot
62 exclusively rely on the PMU's hardware exception filtering - therefore we
63 must enable/disable counting on the entry and exit to the guest. This is
64 performed differently on VHE and non-VHE systems.
66 For non-VHE systems we exclude EL2 for exclude_host - upon entering and
67 exiting the guest we disable/enable the event as appropriate based on the
68 exclude_host and exclude_guest attributes.
70 For VHE systems we exclude EL1 for exclude_guest and exclude both EL0,EL2
71 for exclude_host. Upon entering and exiting the guest we modify the event
72 to include/exclude EL0 as appropriate based on the exclude_host and
73 exclude_guest attributes.
75 The statements above also apply when these attributes are used within a
76 non-VHE guest however please note that EL2 is never counted within a guest.
79 Accuracy
80 --------
82 On non-VHE hosts we enable/disable counters on the entry/exit of host/guest
83 transition at EL2 - however there is a period of time between
84 enabling/disabling the counters and entering/exiting the guest. We are
85 able to eliminate counters counting host events on the boundaries of guest
86 entry/exit when counting guest events by filtering out EL2 for
87 exclude_host. However when using !exclude_hv there is a small blackout
88 window at the guest entry/exit where host events are not captured.
90 On VHE systems there are no blackout windows.