| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 1 | /**************************************************************************** | 
 | 2 |  **************************************************************************** | 
 | 3 |  *** | 
 | 4 |  ***   This header was automatically generated from a Linux kernel header | 
 | 5 |  ***   of the same name, to make information necessary for userspace to | 
 | 6 |  ***   call into the kernel available to libc.  It contains only constants, | 
 | 7 |  ***   structures, and macros generated from the original header, and thus, | 
 | 8 |  ***   contains no copyrightable information. | 
 | 9 |  *** | 
 | 10 |  ***   To edit the content of this header, modify the corresponding | 
 | 11 |  ***   source file (e.g. under external/kernel-headers/original/) then | 
 | 12 |  ***   run bionic/libc/kernel/tools/update_all.py | 
 | 13 |  *** | 
 | 14 |  ***   Any manual change here will be lost the next time this script will | 
 | 15 |  ***   be run. You've been warned! | 
 | 16 |  *** | 
 | 17 |  **************************************************************************** | 
 | 18 |  ****************************************************************************/ | 
 | 19 | #ifndef _UAPI_LINUX_PERF_EVENT_H | 
 | 20 | #define _UAPI_LINUX_PERF_EVENT_H | 
 | 21 | #include <linux/types.h> | 
 | 22 | #include <linux/ioctl.h> | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 23 | #include <asm/byteorder.h> | 
 | 24 | enum perf_type_id { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 25 |   PERF_TYPE_HARDWARE = 0, | 
 | 26 |   PERF_TYPE_SOFTWARE = 1, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 27 |   PERF_TYPE_TRACEPOINT = 2, | 
 | 28 |   PERF_TYPE_HW_CACHE = 3, | 
 | 29 |   PERF_TYPE_RAW = 4, | 
 | 30 |   PERF_TYPE_BREAKPOINT = 5, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 31 |   PERF_TYPE_MAX, | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 32 | }; | 
 | 33 | enum perf_hw_id { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 34 |   PERF_COUNT_HW_CPU_CYCLES = 0, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 35 |   PERF_COUNT_HW_INSTRUCTIONS = 1, | 
 | 36 |   PERF_COUNT_HW_CACHE_REFERENCES = 2, | 
 | 37 |   PERF_COUNT_HW_CACHE_MISSES = 3, | 
 | 38 |   PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 4, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 39 |   PERF_COUNT_HW_BRANCH_MISSES = 5, | 
 | 40 |   PERF_COUNT_HW_BUS_CYCLES = 6, | 
 | 41 |   PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 7, | 
 | 42 |   PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 8, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 43 |   PERF_COUNT_HW_REF_CPU_CYCLES = 9, | 
 | 44 |   PERF_COUNT_HW_MAX, | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 45 | }; | 
 | 46 | enum perf_hw_cache_id { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 47 |   PERF_COUNT_HW_CACHE_L1D = 0, | 
 | 48 |   PERF_COUNT_HW_CACHE_L1I = 1, | 
 | 49 |   PERF_COUNT_HW_CACHE_LL = 2, | 
 | 50 |   PERF_COUNT_HW_CACHE_DTLB = 3, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 51 |   PERF_COUNT_HW_CACHE_ITLB = 4, | 
 | 52 |   PERF_COUNT_HW_CACHE_BPU = 5, | 
 | 53 |   PERF_COUNT_HW_CACHE_NODE = 6, | 
 | 54 |   PERF_COUNT_HW_CACHE_MAX, | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 55 | }; | 
 | 56 | enum perf_hw_cache_op_id { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 57 |   PERF_COUNT_HW_CACHE_OP_READ = 0, | 
 | 58 |   PERF_COUNT_HW_CACHE_OP_WRITE = 1, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 59 |   PERF_COUNT_HW_CACHE_OP_PREFETCH = 2, | 
 | 60 |   PERF_COUNT_HW_CACHE_OP_MAX, | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 61 | }; | 
 | 62 | enum perf_hw_cache_op_result_id { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 63 |   PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0, | 
 | 64 |   PERF_COUNT_HW_CACHE_RESULT_MISS = 1, | 
 | 65 |   PERF_COUNT_HW_CACHE_RESULT_MAX, | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 66 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 67 | enum perf_sw_ids { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 68 |   PERF_COUNT_SW_CPU_CLOCK = 0, | 
 | 69 |   PERF_COUNT_SW_TASK_CLOCK = 1, | 
 | 70 |   PERF_COUNT_SW_PAGE_FAULTS = 2, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 71 |   PERF_COUNT_SW_CONTEXT_SWITCHES = 3, | 
 | 72 |   PERF_COUNT_SW_CPU_MIGRATIONS = 4, | 
 | 73 |   PERF_COUNT_SW_PAGE_FAULTS_MIN = 5, | 
 | 74 |   PERF_COUNT_SW_PAGE_FAULTS_MAJ = 6, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 75 |   PERF_COUNT_SW_ALIGNMENT_FAULTS = 7, | 
 | 76 |   PERF_COUNT_SW_EMULATION_FAULTS = 8, | 
 | 77 |   PERF_COUNT_SW_DUMMY = 9, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 78 |   PERF_COUNT_SW_BPF_OUTPUT = 10, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 79 |   PERF_COUNT_SW_MAX, | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 80 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 81 | enum perf_event_sample_format { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 82 |   PERF_SAMPLE_IP = 1U << 0, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 83 |   PERF_SAMPLE_TID = 1U << 1, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 84 |   PERF_SAMPLE_TIME = 1U << 2, | 
 | 85 |   PERF_SAMPLE_ADDR = 1U << 3, | 
 | 86 |   PERF_SAMPLE_READ = 1U << 4, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 87 |   PERF_SAMPLE_CALLCHAIN = 1U << 5, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 88 |   PERF_SAMPLE_ID = 1U << 6, | 
 | 89 |   PERF_SAMPLE_CPU = 1U << 7, | 
 | 90 |   PERF_SAMPLE_PERIOD = 1U << 8, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 91 |   PERF_SAMPLE_STREAM_ID = 1U << 9, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 92 |   PERF_SAMPLE_RAW = 1U << 10, | 
 | 93 |   PERF_SAMPLE_BRANCH_STACK = 1U << 11, | 
 | 94 |   PERF_SAMPLE_REGS_USER = 1U << 12, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 95 |   PERF_SAMPLE_STACK_USER = 1U << 13, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 96 |   PERF_SAMPLE_WEIGHT = 1U << 14, | 
 | 97 |   PERF_SAMPLE_DATA_SRC = 1U << 15, | 
 | 98 |   PERF_SAMPLE_IDENTIFIER = 1U << 16, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 99 |   PERF_SAMPLE_TRANSACTION = 1U << 17, | 
 | 100 |   PERF_SAMPLE_REGS_INTR = 1U << 18, | 
| Christopher Ferris | 1308ad3 | 2017-11-14 17:32:13 -0800 | [diff] [blame] | 101 |   PERF_SAMPLE_PHYS_ADDR = 1U << 19, | 
 | 102 |   PERF_SAMPLE_MAX = 1U << 20, | 
| Christopher Ferris | 9ce2884 | 2018-10-25 12:11:39 -0700 | [diff] [blame] | 103 |   __PERF_SAMPLE_CALLCHAIN_EARLY = 1ULL << 63, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 104 | }; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 105 | enum perf_branch_sample_type_shift { | 
 | 106 |   PERF_SAMPLE_BRANCH_USER_SHIFT = 0, | 
 | 107 |   PERF_SAMPLE_BRANCH_KERNEL_SHIFT = 1, | 
 | 108 |   PERF_SAMPLE_BRANCH_HV_SHIFT = 2, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 109 |   PERF_SAMPLE_BRANCH_ANY_SHIFT = 3, | 
 | 110 |   PERF_SAMPLE_BRANCH_ANY_CALL_SHIFT = 4, | 
 | 111 |   PERF_SAMPLE_BRANCH_ANY_RETURN_SHIFT = 5, | 
 | 112 |   PERF_SAMPLE_BRANCH_IND_CALL_SHIFT = 6, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 113 |   PERF_SAMPLE_BRANCH_ABORT_TX_SHIFT = 7, | 
 | 114 |   PERF_SAMPLE_BRANCH_IN_TX_SHIFT = 8, | 
 | 115 |   PERF_SAMPLE_BRANCH_NO_TX_SHIFT = 9, | 
 | 116 |   PERF_SAMPLE_BRANCH_COND_SHIFT = 10, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 117 |   PERF_SAMPLE_BRANCH_CALL_STACK_SHIFT = 11, | 
 | 118 |   PERF_SAMPLE_BRANCH_IND_JUMP_SHIFT = 12, | 
 | 119 |   PERF_SAMPLE_BRANCH_CALL_SHIFT = 13, | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 120 |   PERF_SAMPLE_BRANCH_NO_FLAGS_SHIFT = 14, | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 121 |   PERF_SAMPLE_BRANCH_NO_CYCLES_SHIFT = 15, | 
| Christopher Ferris | 1308ad3 | 2017-11-14 17:32:13 -0800 | [diff] [blame] | 122 |   PERF_SAMPLE_BRANCH_TYPE_SAVE_SHIFT = 16, | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 123 |   PERF_SAMPLE_BRANCH_MAX_SHIFT | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 124 | }; | 
 | 125 | enum perf_branch_sample_type { | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 126 |   PERF_SAMPLE_BRANCH_USER = 1U << PERF_SAMPLE_BRANCH_USER_SHIFT, | 
 | 127 |   PERF_SAMPLE_BRANCH_KERNEL = 1U << PERF_SAMPLE_BRANCH_KERNEL_SHIFT, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 128 |   PERF_SAMPLE_BRANCH_HV = 1U << PERF_SAMPLE_BRANCH_HV_SHIFT, | 
 | 129 |   PERF_SAMPLE_BRANCH_ANY = 1U << PERF_SAMPLE_BRANCH_ANY_SHIFT, | 
 | 130 |   PERF_SAMPLE_BRANCH_ANY_CALL = 1U << PERF_SAMPLE_BRANCH_ANY_CALL_SHIFT, | 
 | 131 |   PERF_SAMPLE_BRANCH_ANY_RETURN = 1U << PERF_SAMPLE_BRANCH_ANY_RETURN_SHIFT, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 132 |   PERF_SAMPLE_BRANCH_IND_CALL = 1U << PERF_SAMPLE_BRANCH_IND_CALL_SHIFT, | 
 | 133 |   PERF_SAMPLE_BRANCH_ABORT_TX = 1U << PERF_SAMPLE_BRANCH_ABORT_TX_SHIFT, | 
 | 134 |   PERF_SAMPLE_BRANCH_IN_TX = 1U << PERF_SAMPLE_BRANCH_IN_TX_SHIFT, | 
 | 135 |   PERF_SAMPLE_BRANCH_NO_TX = 1U << PERF_SAMPLE_BRANCH_NO_TX_SHIFT, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 136 |   PERF_SAMPLE_BRANCH_COND = 1U << PERF_SAMPLE_BRANCH_COND_SHIFT, | 
 | 137 |   PERF_SAMPLE_BRANCH_CALL_STACK = 1U << PERF_SAMPLE_BRANCH_CALL_STACK_SHIFT, | 
 | 138 |   PERF_SAMPLE_BRANCH_IND_JUMP = 1U << PERF_SAMPLE_BRANCH_IND_JUMP_SHIFT, | 
 | 139 |   PERF_SAMPLE_BRANCH_CALL = 1U << PERF_SAMPLE_BRANCH_CALL_SHIFT, | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 140 |   PERF_SAMPLE_BRANCH_NO_FLAGS = 1U << PERF_SAMPLE_BRANCH_NO_FLAGS_SHIFT, | 
 | 141 |   PERF_SAMPLE_BRANCH_NO_CYCLES = 1U << PERF_SAMPLE_BRANCH_NO_CYCLES_SHIFT, | 
| Christopher Ferris | 1308ad3 | 2017-11-14 17:32:13 -0800 | [diff] [blame] | 142 |   PERF_SAMPLE_BRANCH_TYPE_SAVE = 1U << PERF_SAMPLE_BRANCH_TYPE_SAVE_SHIFT, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 143 |   PERF_SAMPLE_BRANCH_MAX = 1U << PERF_SAMPLE_BRANCH_MAX_SHIFT, | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 144 | }; | 
| Christopher Ferris | 1308ad3 | 2017-11-14 17:32:13 -0800 | [diff] [blame] | 145 | enum { | 
 | 146 |   PERF_BR_UNKNOWN = 0, | 
 | 147 |   PERF_BR_COND = 1, | 
 | 148 |   PERF_BR_UNCOND = 2, | 
 | 149 |   PERF_BR_IND = 3, | 
 | 150 |   PERF_BR_CALL = 4, | 
 | 151 |   PERF_BR_IND_CALL = 5, | 
 | 152 |   PERF_BR_RET = 6, | 
 | 153 |   PERF_BR_SYSCALL = 7, | 
 | 154 |   PERF_BR_SYSRET = 8, | 
 | 155 |   PERF_BR_COND_CALL = 9, | 
 | 156 |   PERF_BR_COND_RET = 10, | 
 | 157 |   PERF_BR_MAX, | 
 | 158 | }; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 159 | #define PERF_SAMPLE_BRANCH_PLM_ALL (PERF_SAMPLE_BRANCH_USER | PERF_SAMPLE_BRANCH_KERNEL | PERF_SAMPLE_BRANCH_HV) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 160 | enum perf_sample_regs_abi { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 161 |   PERF_SAMPLE_REGS_ABI_NONE = 0, | 
 | 162 |   PERF_SAMPLE_REGS_ABI_32 = 1, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 163 |   PERF_SAMPLE_REGS_ABI_64 = 2, | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 164 | }; | 
 | 165 | enum { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 166 |   PERF_TXN_ELISION = (1 << 0), | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 167 |   PERF_TXN_TRANSACTION = (1 << 1), | 
 | 168 |   PERF_TXN_SYNC = (1 << 2), | 
 | 169 |   PERF_TXN_ASYNC = (1 << 3), | 
 | 170 |   PERF_TXN_RETRY = (1 << 4), | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 171 |   PERF_TXN_CONFLICT = (1 << 5), | 
 | 172 |   PERF_TXN_CAPACITY_WRITE = (1 << 6), | 
 | 173 |   PERF_TXN_CAPACITY_READ = (1 << 7), | 
 | 174 |   PERF_TXN_MAX = (1 << 8), | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 175 |   PERF_TXN_ABORT_MASK = (0xffffffffULL << 32), | 
 | 176 |   PERF_TXN_ABORT_SHIFT = 32, | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 177 | }; | 
 | 178 | enum perf_event_read_format { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 179 |   PERF_FORMAT_TOTAL_TIME_ENABLED = 1U << 0, | 
 | 180 |   PERF_FORMAT_TOTAL_TIME_RUNNING = 1U << 1, | 
 | 181 |   PERF_FORMAT_ID = 1U << 2, | 
 | 182 |   PERF_FORMAT_GROUP = 1U << 3, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 183 |   PERF_FORMAT_MAX = 1U << 4, | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 184 | }; | 
 | 185 | #define PERF_ATTR_SIZE_VER0 64 | 
 | 186 | #define PERF_ATTR_SIZE_VER1 72 | 
| Christopher Ferris | ba8d4f4 | 2014-09-03 19:56:49 -0700 | [diff] [blame] | 187 | #define PERF_ATTR_SIZE_VER2 80 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 188 | #define PERF_ATTR_SIZE_VER3 96 | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 189 | #define PERF_ATTR_SIZE_VER4 104 | 
 | 190 | #define PERF_ATTR_SIZE_VER5 112 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 191 | struct perf_event_attr { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 192 |   __u32 type; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 193 |   __u32 size; | 
 | 194 |   __u64 config; | 
 | 195 |   union { | 
 | 196 |     __u64 sample_period; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 197 |     __u64 sample_freq; | 
 | 198 |   }; | 
 | 199 |   __u64 sample_type; | 
 | 200 |   __u64 read_format; | 
| Christopher Ferris | 525ce91 | 2017-07-26 13:12:53 -0700 | [diff] [blame] | 201 |   __u64 disabled : 1, inherit : 1, pinned : 1, exclusive : 1, exclude_user : 1, exclude_kernel : 1, exclude_hv : 1, exclude_idle : 1, mmap : 1, comm : 1, freq : 1, inherit_stat : 1, enable_on_exec : 1, task : 1, watermark : 1, precise_ip : 2, mmap_data : 1, sample_id_all : 1, exclude_host : 1, exclude_guest : 1, exclude_callchain_kernel : 1, exclude_callchain_user : 1, mmap2 : 1, comm_exec : 1, use_clockid : 1, context_switch : 1, write_backward : 1, namespaces : 1, __reserved_1 : 35; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 202 |   union { | 
 | 203 |     __u32 wakeup_events; | 
 | 204 |     __u32 wakeup_watermark; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 205 |   }; | 
 | 206 |   __u32 bp_type; | 
 | 207 |   union { | 
 | 208 |     __u64 bp_addr; | 
| Christopher Ferris | 76a1d45 | 2018-06-27 14:12:29 -0700 | [diff] [blame] | 209 |     __u64 kprobe_func; | 
 | 210 |     __u64 uprobe_path; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 211 |     __u64 config1; | 
 | 212 |   }; | 
 | 213 |   union { | 
 | 214 |     __u64 bp_len; | 
| Christopher Ferris | 76a1d45 | 2018-06-27 14:12:29 -0700 | [diff] [blame] | 215 |     __u64 kprobe_addr; | 
 | 216 |     __u64 probe_offset; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 217 |     __u64 config2; | 
 | 218 |   }; | 
 | 219 |   __u64 branch_sample_type; | 
 | 220 |   __u64 sample_regs_user; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 221 |   __u32 sample_stack_user; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 222 |   __s32 clockid; | 
 | 223 |   __u64 sample_regs_intr; | 
 | 224 |   __u32 aux_watermark; | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 225 |   __u16 sample_max_stack; | 
 | 226 |   __u16 __reserved_2; | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 227 | }; | 
| Christopher Ferris | 76a1d45 | 2018-06-27 14:12:29 -0700 | [diff] [blame] | 228 | struct perf_event_query_bpf { | 
 | 229 |   __u32 ids_len; | 
 | 230 |   __u32 prog_cnt; | 
 | 231 |   __u32 ids[0]; | 
 | 232 | }; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 233 | #define perf_flags(attr) (* (& (attr)->read_format + 1)) | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 234 | #define PERF_EVENT_IOC_ENABLE _IO('$', 0) | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 235 | #define PERF_EVENT_IOC_DISABLE _IO('$', 1) | 
 | 236 | #define PERF_EVENT_IOC_REFRESH _IO('$', 2) | 
 | 237 | #define PERF_EVENT_IOC_RESET _IO('$', 3) | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 238 | #define PERF_EVENT_IOC_PERIOD _IOW('$', 4, __u64) | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 239 | #define PERF_EVENT_IOC_SET_OUTPUT _IO('$', 5) | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 240 | #define PERF_EVENT_IOC_SET_FILTER _IOW('$', 6, char *) | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 241 | #define PERF_EVENT_IOC_ID _IOR('$', 7, __u64 *) | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 242 | #define PERF_EVENT_IOC_SET_BPF _IOW('$', 8, __u32) | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 243 | #define PERF_EVENT_IOC_PAUSE_OUTPUT _IOW('$', 9, __u32) | 
| Christopher Ferris | 76a1d45 | 2018-06-27 14:12:29 -0700 | [diff] [blame] | 244 | #define PERF_EVENT_IOC_QUERY_BPF _IOWR('$', 10, struct perf_event_query_bpf *) | 
 | 245 | #define PERF_EVENT_IOC_MODIFY_ATTRIBUTES _IOW('$', 11, struct perf_event_attr *) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 246 | enum perf_event_ioc_flags { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 247 |   PERF_IOC_FLAG_GROUP = 1U << 0, | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 248 | }; | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 249 | struct perf_event_mmap_page { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 250 |   __u32 version; | 
 | 251 |   __u32 compat_version; | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 252 |   __u32 lock; | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 253 |   __u32 index; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 254 |   __s64 offset; | 
 | 255 |   __u64 time_enabled; | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 256 |   __u64 time_running; | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 257 |   union { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 258 |     __u64 capabilities; | 
 | 259 |     struct { | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 260 |       __u64 cap_bit0 : 1, cap_bit0_is_deprecated : 1, cap_user_rdpmc : 1, cap_user_time : 1, cap_user_time_zero : 1, cap_____res : 59; | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 261 |     }; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 262 |   }; | 
 | 263 |   __u16 pmc_width; | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 264 |   __u16 time_shift; | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 265 |   __u32 time_mult; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 266 |   __u64 time_offset; | 
 | 267 |   __u64 time_zero; | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 268 |   __u32 size; | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 269 |   __u8 __reserved[118 * 8 + 4]; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 270 |   __u64 data_head; | 
 | 271 |   __u64 data_tail; | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 272 |   __u64 data_offset; | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 273 |   __u64 data_size; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 274 |   __u64 aux_head; | 
 | 275 |   __u64 aux_tail; | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 276 |   __u64 aux_offset; | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 277 |   __u64 aux_size; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 278 | }; | 
 | 279 | #define PERF_RECORD_MISC_CPUMODE_MASK (7 << 0) | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 280 | #define PERF_RECORD_MISC_CPUMODE_UNKNOWN (0 << 0) | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 281 | #define PERF_RECORD_MISC_KERNEL (1 << 0) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 282 | #define PERF_RECORD_MISC_USER (2 << 0) | 
 | 283 | #define PERF_RECORD_MISC_HYPERVISOR (3 << 0) | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 284 | #define PERF_RECORD_MISC_GUEST_KERNEL (4 << 0) | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 285 | #define PERF_RECORD_MISC_GUEST_USER (5 << 0) | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 286 | #define PERF_RECORD_MISC_PROC_MAP_PARSE_TIMEOUT (1 << 12) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 287 | #define PERF_RECORD_MISC_MMAP_DATA (1 << 13) | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 288 | #define PERF_RECORD_MISC_COMM_EXEC (1 << 13) | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 289 | #define PERF_RECORD_MISC_SWITCH_OUT (1 << 13) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 290 | #define PERF_RECORD_MISC_EXACT_IP (1 << 14) | 
| Christopher Ferris | 76a1d45 | 2018-06-27 14:12:29 -0700 | [diff] [blame] | 291 | #define PERF_RECORD_MISC_SWITCH_OUT_PREEMPT (1 << 14) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 292 | #define PERF_RECORD_MISC_EXT_RESERVED (1 << 15) | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 293 | struct perf_event_header { | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 294 |   __u32 type; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 295 |   __u16 misc; | 
 | 296 |   __u16 size; | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 297 | }; | 
| Christopher Ferris | 525ce91 | 2017-07-26 13:12:53 -0700 | [diff] [blame] | 298 | struct perf_ns_link_info { | 
 | 299 |   __u64 dev; | 
 | 300 |   __u64 ino; | 
 | 301 | }; | 
 | 302 | enum { | 
 | 303 |   NET_NS_INDEX = 0, | 
 | 304 |   UTS_NS_INDEX = 1, | 
 | 305 |   IPC_NS_INDEX = 2, | 
 | 306 |   PID_NS_INDEX = 3, | 
 | 307 |   USER_NS_INDEX = 4, | 
 | 308 |   MNT_NS_INDEX = 5, | 
 | 309 |   CGROUP_NS_INDEX = 6, | 
 | 310 |   NR_NAMESPACES, | 
 | 311 | }; | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 312 | enum perf_event_type { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 313 |   PERF_RECORD_MMAP = 1, | 
 | 314 |   PERF_RECORD_LOST = 2, | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 315 |   PERF_RECORD_COMM = 3, | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 316 |   PERF_RECORD_EXIT = 4, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 317 |   PERF_RECORD_THROTTLE = 5, | 
 | 318 |   PERF_RECORD_UNTHROTTLE = 6, | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 319 |   PERF_RECORD_FORK = 7, | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 320 |   PERF_RECORD_READ = 8, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 321 |   PERF_RECORD_SAMPLE = 9, | 
 | 322 |   PERF_RECORD_MMAP2 = 10, | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 323 |   PERF_RECORD_AUX = 11, | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 324 |   PERF_RECORD_ITRACE_START = 12, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 325 |   PERF_RECORD_LOST_SAMPLES = 13, | 
 | 326 |   PERF_RECORD_SWITCH = 14, | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 327 |   PERF_RECORD_SWITCH_CPU_WIDE = 15, | 
| Christopher Ferris | 525ce91 | 2017-07-26 13:12:53 -0700 | [diff] [blame] | 328 |   PERF_RECORD_NAMESPACES = 16, | 
| Christopher Ferris | 106b3a8 | 2016-08-24 12:15:38 -0700 | [diff] [blame] | 329 |   PERF_RECORD_MAX, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 330 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 331 | #define PERF_MAX_STACK_DEPTH 127 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 332 | #define PERF_MAX_CONTEXTS_PER_STACK 8 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 333 | enum perf_callchain_context { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 334 |   PERF_CONTEXT_HV = (__u64) - 32, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 335 |   PERF_CONTEXT_KERNEL = (__u64) - 128, | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 336 |   PERF_CONTEXT_USER = (__u64) - 512, | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 337 |   PERF_CONTEXT_GUEST = (__u64) - 2048, | 
 | 338 |   PERF_CONTEXT_GUEST_KERNEL = (__u64) - 2176, | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 339 |   PERF_CONTEXT_GUEST_USER = (__u64) - 2560, | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 340 |   PERF_CONTEXT_MAX = (__u64) - 4095, | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 341 | }; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 342 | #define PERF_AUX_FLAG_TRUNCATED 0x01 | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 343 | #define PERF_AUX_FLAG_OVERWRITE 0x02 | 
| Christopher Ferris | 525ce91 | 2017-07-26 13:12:53 -0700 | [diff] [blame] | 344 | #define PERF_AUX_FLAG_PARTIAL 0x04 | 
| Christopher Ferris | 934ec94 | 2018-01-31 15:29:16 -0800 | [diff] [blame] | 345 | #define PERF_AUX_FLAG_COLLISION 0x08 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 346 | #define PERF_FLAG_FD_NO_GROUP (1UL << 0) | 
| Christopher Ferris | ba8d4f4 | 2014-09-03 19:56:49 -0700 | [diff] [blame] | 347 | #define PERF_FLAG_FD_OUTPUT (1UL << 1) | 
 | 348 | #define PERF_FLAG_PID_CGROUP (1UL << 2) | 
 | 349 | #define PERF_FLAG_FD_CLOEXEC (1UL << 3) | 
| Christopher Ferris | 525ce91 | 2017-07-26 13:12:53 -0700 | [diff] [blame] | 350 | #ifdef __LITTLE_ENDIAN_BITFIELD | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 351 | union perf_mem_data_src { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 352 |   __u64 val; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 353 |   struct { | 
| Christopher Ferris | 1308ad3 | 2017-11-14 17:32:13 -0800 | [diff] [blame] | 354 |     __u64 mem_op : 5, mem_lvl : 14, mem_snoop : 5, mem_lock : 2, mem_dtlb : 7, mem_lvl_num : 4, mem_remote : 1, mem_snoopx : 2, mem_rsvd : 24; | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 355 |   }; | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 356 | }; | 
| Christopher Ferris | 525ce91 | 2017-07-26 13:12:53 -0700 | [diff] [blame] | 357 | #elif defined(__BIG_ENDIAN_BITFIELD) | 
 | 358 | union perf_mem_data_src { | 
 | 359 |   __u64 val; | 
 | 360 |   struct { | 
| Christopher Ferris | 1308ad3 | 2017-11-14 17:32:13 -0800 | [diff] [blame] | 361 |     __u64 mem_rsvd : 24, mem_snoopx : 2, mem_remote : 1, mem_lvl_num : 4, mem_dtlb : 7, mem_lock : 2, mem_snoop : 5, mem_lvl : 14, mem_op : 5; | 
| Christopher Ferris | 525ce91 | 2017-07-26 13:12:53 -0700 | [diff] [blame] | 362 |   }; | 
 | 363 | }; | 
 | 364 | #else | 
 | 365 | #error "Unknown endianness" | 
 | 366 | #endif | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 367 | #define PERF_MEM_OP_NA 0x01 | 
 | 368 | #define PERF_MEM_OP_LOAD 0x02 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 369 | #define PERF_MEM_OP_STORE 0x04 | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 370 | #define PERF_MEM_OP_PFETCH 0x08 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 371 | #define PERF_MEM_OP_EXEC 0x10 | 
 | 372 | #define PERF_MEM_OP_SHIFT 0 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 373 | #define PERF_MEM_LVL_NA 0x01 | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 374 | #define PERF_MEM_LVL_HIT 0x02 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 375 | #define PERF_MEM_LVL_MISS 0x04 | 
 | 376 | #define PERF_MEM_LVL_L1 0x08 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 377 | #define PERF_MEM_LVL_LFB 0x10 | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 378 | #define PERF_MEM_LVL_L2 0x20 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 379 | #define PERF_MEM_LVL_L3 0x40 | 
 | 380 | #define PERF_MEM_LVL_LOC_RAM 0x80 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 381 | #define PERF_MEM_LVL_REM_RAM1 0x100 | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 382 | #define PERF_MEM_LVL_REM_RAM2 0x200 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 383 | #define PERF_MEM_LVL_REM_CCE1 0x400 | 
 | 384 | #define PERF_MEM_LVL_REM_CCE2 0x800 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 385 | #define PERF_MEM_LVL_IO 0x1000 | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 386 | #define PERF_MEM_LVL_UNC 0x2000 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 387 | #define PERF_MEM_LVL_SHIFT 5 | 
| Christopher Ferris | 1308ad3 | 2017-11-14 17:32:13 -0800 | [diff] [blame] | 388 | #define PERF_MEM_REMOTE_REMOTE 0x01 | 
 | 389 | #define PERF_MEM_REMOTE_SHIFT 37 | 
 | 390 | #define PERF_MEM_LVLNUM_L1 0x01 | 
 | 391 | #define PERF_MEM_LVLNUM_L2 0x02 | 
 | 392 | #define PERF_MEM_LVLNUM_L3 0x03 | 
 | 393 | #define PERF_MEM_LVLNUM_L4 0x04 | 
 | 394 | #define PERF_MEM_LVLNUM_ANY_CACHE 0x0b | 
 | 395 | #define PERF_MEM_LVLNUM_LFB 0x0c | 
 | 396 | #define PERF_MEM_LVLNUM_RAM 0x0d | 
 | 397 | #define PERF_MEM_LVLNUM_PMEM 0x0e | 
 | 398 | #define PERF_MEM_LVLNUM_NA 0x0f | 
 | 399 | #define PERF_MEM_LVLNUM_SHIFT 33 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 400 | #define PERF_MEM_SNOOP_NA 0x01 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 401 | #define PERF_MEM_SNOOP_NONE 0x02 | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 402 | #define PERF_MEM_SNOOP_HIT 0x04 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 403 | #define PERF_MEM_SNOOP_MISS 0x08 | 
 | 404 | #define PERF_MEM_SNOOP_HITM 0x10 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 405 | #define PERF_MEM_SNOOP_SHIFT 19 | 
| Christopher Ferris | 1308ad3 | 2017-11-14 17:32:13 -0800 | [diff] [blame] | 406 | #define PERF_MEM_SNOOPX_FWD 0x01 | 
 | 407 | #define PERF_MEM_SNOOPX_SHIFT 37 | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 408 | #define PERF_MEM_LOCK_NA 0x01 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 409 | #define PERF_MEM_LOCK_LOCKED 0x02 | 
 | 410 | #define PERF_MEM_LOCK_SHIFT 24 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 411 | #define PERF_MEM_TLB_NA 0x01 | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 412 | #define PERF_MEM_TLB_HIT 0x02 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 413 | #define PERF_MEM_TLB_MISS 0x04 | 
 | 414 | #define PERF_MEM_TLB_L1 0x08 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 415 | #define PERF_MEM_TLB_L2 0x10 | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 416 | #define PERF_MEM_TLB_WK 0x20 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 417 | #define PERF_MEM_TLB_OS 0x40 | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 418 | #define PERF_MEM_TLB_SHIFT 26 | 
| Christopher Ferris | 49f525c | 2016-12-12 14:55:36 -0800 | [diff] [blame] | 419 | #define PERF_MEM_S(a,s) (((__u64) PERF_MEM_ ##a ##_ ##s) << PERF_MEM_ ##a ##_SHIFT) | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 420 | struct perf_branch_entry { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 421 |   __u64 from; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 422 |   __u64 to; | 
| Christopher Ferris | 1308ad3 | 2017-11-14 17:32:13 -0800 | [diff] [blame] | 423 |   __u64 mispred : 1, predicted : 1, in_tx : 1, abort : 1, cycles : 16, type : 4, reserved : 40; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 424 | }; | 
| Elliott Hughes | 8cb52b0 | 2013-11-21 13:43:23 -0800 | [diff] [blame] | 425 | #endif |