CMSIS-Core (Cortex-M)  Version 5.6.0
CMSIS-Core support for Cortex-M processor-based devices
 All Data Structures Files Functions Variables Enumerations Enumerator Groups Pages
PMU Events for Armv8.1-M

IDs for Armv8.1-M architecture defined events. More...

Macros

#define ARM_PMU_SW_INCR   0x0000
 Software update to the PMU_SWINC register, architecturally executed and condition code check pass. More...
 
#define ARM_PMU_L1I_CACHE_REFILL   0x0001
 L1 I-Cache refill. More...
 
#define ARM_PMU_L1D_CACHE_REFILL   0x0003
 L1 D-Cache refill. More...
 
#define ARM_PMU_L1D_CACHE   0x0004
 L1 D-Cache access. More...
 
#define ARM_PMU_LD_RETIRED   0x0006
 Memory-reading instruction architecturally executed and condition code check pass. More...
 
#define ARM_PMU_ST_RETIRED   0x0007
 Memory-writing instruction architecturally executed and condition code check pass. More...
 
#define ARM_PMU_INST_RETIRED   0x0008
 Instruction architecturally executed. More...
 
#define ARM_PMU_EXC_TAKEN   0x0009
 Exception entry. More...
 
#define ARM_PMU_EXC_RETURN   0x000A
 Exception return instruction architecturally executed and the condition code check pass. More...
 
#define ARM_PMU_PC_WRITE_RETIRED   0x000C
 Software change to the Program Counter (PC). Instruction is architecturally executed and condition code check pass. More...
 
#define ARM_PMU_BR_IMMED_RETIRED   0x000D
 Immediate branch architecturally executed. More...
 
#define ARM_PMU_BR_RETURN_RETIRED   0x000E
 Function return instruction architecturally executed and the condition code check pass. More...
 
#define ARM_PMU_UNALIGNED_LDST_RETIRED   0x000F
 Unaligned memory memory-reading or memory-writing instruction architecturally executed and condition code check pass. More...
 
#define ARM_PMU_BR_MIS_PRED   0x0010
 Mispredicted or not predicted branch speculatively executed. More...
 
#define ARM_PMU_CPU_CYCLES   0x0011
 Cycle. More...
 
#define ARM_PMU_BR_PRED   0x0012
 Predictable branch speculatively executed. More...
 
#define ARM_PMU_MEM_ACCESS   0x0013
 Data memory access. More...
 
#define ARM_PMU_L1I_CACHE   0x0014
 Level 1 instruction cache access. More...
 
#define ARM_PMU_L1D_CACHE_WB   0x0015
 Level 1 data cache write-back. More...
 
#define ARM_PMU_L2D_CACHE   0x0016
 Level 2 data cache access. More...
 
#define ARM_PMU_L2D_CACHE_REFILL   0x0017
 Level 2 data cache refill. More...
 
#define ARM_PMU_L2D_CACHE_WB   0x0018
 Level 2 data cache write-back. More...
 
#define ARM_PMU_BUS_ACCESS   0x0019
 Bus access. More...
 
#define ARM_PMU_MEMORY_ERROR   0x001A
 Local memory error. More...
 
#define ARM_PMU_INST_SPEC   0x001B
 Instruction speculatively executed. More...
 
#define ARM_PMU_BUS_CYCLES   0x001D
 Bus cycles. More...
 
#define ARM_PMU_CHAIN   0x001E
 For an odd numbered counter, increment when an overflow occurs on the preceding even-numbered counter on the same PE. More...
 
#define ARM_PMU_L1D_CACHE_ALLOCATE   0x001F
 Level 1 data cache allocation without refill. More...
 
#define ARM_PMU_L2D_CACHE_ALLOCATE   0x0020
 Level 2 data cache allocation without refill. More...
 
#define ARM_PMU_BR_RETIRED   0x0021
 Branch instruction architecturally executed. More...
 
#define ARM_PMU_BR_MIS_PRED_RETIRED   0x0022
 Mispredicted branch instruction architecturally executed. More...
 
#define ARM_PMU_STALL_FRONTEND   0x0023
 No operation issued because of the frontend. More...
 
#define ARM_PMU_STALL_BACKEND   0x0024
 No operation issued because of the backend. More...
 
#define ARM_PMU_L2I_CACHE   0x0027
 Level 2 instruction cache access. More...
 
#define ARM_PMU_L2I_CACHE_REFILL   0x0028
 Level 2 instruction cache refill. More...
 
#define ARM_PMU_L3D_CACHE_ALLOCATE   0x0029
 Level 3 data cache allocation without refill. More...
 
#define ARM_PMU_L3D_CACHE_REFILL   0x002A
 Level 3 data cache refill. More...
 
#define ARM_PMU_L3D_CACHE   0x002B
 Level 3 data cache access. More...
 
#define ARM_PMU_L3D_CACHE_WB   0x002C
 Level 3 data cache write-back. More...
 
#define ARM_PMU_LL_CACHE_RD   0x0036
 Last level data cache read. More...
 
#define ARM_PMU_LL_CACHE_MISS_RD   0x0037
 Last level data cache read miss. More...
 
#define ARM_PMU_L1D_CACHE_MISS_RD   0x0039
 Level 1 data cache read miss. More...
 
#define ARM_PMU_OP_COMPLETE   0x003A
 Operation retired. More...
 
#define ARM_PMU_OP_SPEC   0x003B
 Operation speculatively executed. More...
 
#define ARM_PMU_STALL   0x003C
 Stall cycle for instruction or operation not sent for execution. More...
 
#define ARM_PMU_STALL_OP_BACKEND   0x003D
 Stall cycle for instruction or operation not sent for execution due to pipeline backend. More...
 
#define ARM_PMU_STALL_OP_FRONTEND   0x003E
 Stall cycle for instruction or operation not sent for execution due to pipeline frontend. More...
 
#define ARM_PMU_STALL_OP   0x003F
 Instruction or operation slots not occupied each cycle. More...
 
#define ARM_PMU_L1D_CACHE_RD   0x0040
 Level 1 data cache read. More...
 
#define ARM_PMU_LE_RETIRED   0x0100
 Loop end instruction executed. More...
 
#define ARM_PMU_LE_SPEC   0x0101
 Loop end instruction speculatively executed. More...
 
#define ARM_PMU_BF_RETIRED   0x0104
 Branch future instruction architecturally executed and condition code check pass. More...
 
#define ARM_PMU_BF_SPEC   0x0105
 Branch future instruction speculatively executed and condition code check pass. More...
 
#define ARM_PMU_LE_CANCEL   0x0108
 Loop end instruction not taken. More...
 
#define ARM_PMU_BF_CANCEL   0x0109
 Branch future instruction not taken. More...
 
#define ARM_PMU_SE_CALL_S   0x0114
 Call to secure function, resulting in Security state change. More...
 
#define ARM_PMU_SE_CALL_NS   0x0115
 Call to non-secure function, resulting in Security state change. More...
 
#define ARM_PMU_DWT_CMPMATCH0   0x0118
 DWT comparator 0 match. More...
 
#define ARM_PMU_DWT_CMPMATCH1   0x0119
 DWT comparator 1 match. More...
 
#define ARM_PMU_DWT_CMPMATCH2   0x011A
 DWT comparator 2 match. More...
 
#define ARM_PMU_DWT_CMPMATCH3   0x011B
 DWT comparator 3 match. More...
 
#define ARM_PMU_MVE_INST_RETIRED   0x0200
 MVE instruction architecturally executed. More...
 
#define ARM_PMU_MVE_INST_SPEC   0x0201
 MVE instruction speculatively executed. More...
 
#define ARM_PMU_MVE_FP_RETIRED   0x0204
 MVE floating-point instruction architecturally executed. More...
 
#define ARM_PMU_MVE_FP_SPEC   0x0205
 MVE floating-point instruction speculatively executed. More...
 
#define ARM_PMU_MVE_FP_HP_RETIRED   0x0208
 MVE half-precision floating-point instruction architecturally executed. More...
 
#define ARM_PMU_MVE_FP_HP_SPEC   0x0209
 MVE half-precision floating-point instruction speculatively executed. More...
 
#define ARM_PMU_MVE_FP_SP_RETIRED   0x020C
 MVE single-precision floating-point instruction architecturally executed. More...
 
#define ARM_PMU_MVE_FP_SP_SPEC   0x020D
 MVE single-precision floating-point instruction speculatively executed. More...
 
#define ARM_PMU_MVE_FP_MAC_RETIRED   0x0214
 MVE floating-point multiply or multiply-accumulate instruction architecturally executed. More...
 
#define ARM_PMU_MVE_FP_MAC_SPEC   0x0215
 MVE floating-point multiply or multiply-accumulate instruction speculatively executed. More...
 
#define ARM_PMU_MVE_INT_RETIRED   0x0224
 MVE integer instruction architecturally executed. More...
 
#define ARM_PMU_MVE_INT_SPEC   0x0225
 MVE integer instruction speculatively executed. More...
 
#define ARM_PMU_MVE_INT_MAC_RETIRED   0x0228
 MVE multiply or multiply-accumulate instruction architecturally executed. More...
 
#define ARM_PMU_MVE_INT_MAC_SPEC   0x0229
 MVE multiply or multiply-accumulate instruction speculatively executed. More...
 
#define ARM_PMU_MVE_LDST_RETIRED   0x0238
 MVE load or store instruction architecturally executed. More...
 
#define ARM_PMU_MVE_LDST_SPEC   0x0239
 MVE load or store instruction speculatively executed. More...
 
#define ARM_PMU_MVE_LD_RETIRED   0x023C
 MVE load instruction architecturally executed. More...
 
#define ARM_PMU_MVE_LD_SPEC   0x023D
 MVE load instruction speculatively executed. More...
 
#define ARM_PMU_MVE_ST_RETIRED   0x0240
 MVE store instruction architecturally executed. More...
 
#define ARM_PMU_MVE_ST_SPEC   0x0241
 MVE store instruction speculatively executed. More...
 
#define ARM_PMU_MVE_LDST_CONTIG_RETIRED   0x0244
 MVE contiguous load or store instruction architecturally executed. More...
 
#define ARM_PMU_MVE_LDST_CONTIG_SPEC   0x0245
 MVE contiguous load or store instruction speculatively executed. More...
 
#define ARM_PMU_MVE_LD_CONTIG_RETIRED   0x0248
 MVE contiguous load instruction architecturally executed. More...
 
#define ARM_PMU_MVE_LD_CONTIG_SPEC   0x0249
 MVE contiguous load instruction speculatively executed. More...
 
#define ARM_PMU_MVE_ST_CONTIG_RETIRED   0x024C
 MVE contiguous store instruction architecturally executed. More...
 
#define ARM_PMU_MVE_ST_CONTIG_SPEC   0x024D
 MVE contiguous store instruction speculatively executed. More...
 
#define ARM_PMU_MVE_LDST_NONCONTIG_RETIRED   0x0250
 MVE non-contiguous load or store instruction architecturally executed. More...
 
#define ARM_PMU_MVE_LDST_NONCONTIG_SPEC   0x0251
 MVE non-contiguous load or store instruction speculatively executed. More...
 
#define ARM_PMU_MVE_LD_NONCONTIG_RETIRED   0x0254
 MVE non-contiguous load instruction architecturally executed. More...
 
#define ARM_PMU_MVE_LD_NONCONTIG_SPEC   0x0255
 MVE non-contiguous load instruction speculatively executed. More...
 
#define ARM_PMU_MVE_ST_NONCONTIG_RETIRED   0x0258
 MVE non-contiguous store instruction architecturally executed. More...
 
#define ARM_PMU_MVE_ST_NONCONTIG_SPEC   0x0259
 MVE non-contiguous store instruction speculatively executed. More...
 
#define ARM_PMU_MVE_LDST_MULTI_RETIRED   0x025C
 MVE memory instruction targeting multiple registers architecturally executed. More...
 
#define ARM_PMU_MVE_LDST_MULTI_SPEC   0x025D
 MVE memory instruction targeting multiple registers speculatively executed. More...
 
#define ARM_PMU_MVE_LD_MULTI_RETIRED   0x0260
 MVE memory load instruction targeting multiple registers architecturally executed. More...
 
#define ARM_PMU_MVE_LD_MULTI_SPEC   0x0261
 MVE memory load instruction targeting multiple registers speculatively executed. More...
 
#define ARM_PMU_MVE_ST_MULTI_RETIRED   0x0261
 MVE memory store instruction targeting multiple registers architecturally executed. More...
 
#define ARM_PMU_MVE_ST_MULTI_SPEC   0x0265
 MVE memory store instruction targeting multiple registers speculatively executed. More...
 
#define ARM_PMU_MVE_LDST_UNALIGNED_RETIRED   0x028C
 MVE unaligned memory load or store instruction architecturally executed. More...
 
#define ARM_PMU_MVE_LDST_UNALIGNED_SPEC   0x028D
 MVE unaligned memory load or store instruction speculatively executed. More...
 
#define ARM_PMU_MVE_LD_UNALIGNED_RETIRED   0x0290
 MVE unaligned load instruction architecturally executed. More...
 
#define ARM_PMU_MVE_LD_UNALIGNED_SPEC   0x0291
 MVE unaligned load instruction speculatively executed. More...
 
#define ARM_PMU_MVE_ST_UNALIGNED_RETIRED   0x0294
 MVE unaligned store instruction architecturally executed. More...
 
#define ARM_PMU_MVE_ST_UNALIGNED_SPEC   0x0295
 MVE unaligned store instruction speculatively executed. More...
 
#define ARM_PMU_MVE_LDST_UNALIGNED_NONCONTIG_RETIRED   0x0298
 MVE unaligned noncontiguous load or store instruction architecturally executed. More...
 
#define ARM_PMU_MVE_LDST_UNALIGNED_NONCONTIG_SPEC   0x0299
 MVE unaligned noncontiguous load or store instruction speculatively executed. More...
 
#define ARM_PMU_MVE_VREDUCE_RETIRED   0x02A0
 MVE vector reduction instruction architecturally executed. More...
 
#define ARM_PMU_MVE_VREDUCE_SPEC   0x02A1
 MVE vector reduction instruction speculatively executed. More...
 
#define ARM_PMU_MVE_VREDUCE_FP_RETIRED   0x02A4
 MVE floating-point vector reduction instruction architecturally executed. More...
 
#define ARM_PMU_MVE_VREDUCE_FP_SPEC   0x02A5
 MVE floating-point vector reduction instruction speculatively executed. More...
 
#define ARM_PMU_MVE_VREDUCE_INT_RETIRED   0x02A8
 MVE integer vector reduction instruction architecturally executed. More...
 
#define ARM_PMU_MVE_VREDUCE_INT_SPEC   0x02A9
 MVE integer vector reduction instruction speculatively executed. More...
 
#define ARM_PMU_MVE_PRED   0x02B8
 Cycles where one or more predicated beats architecturally executed. More...
 
#define ARM_PMU_MVE_STALL   0x02CC
 Stall cycles caused by an MVE instruction. More...
 
#define ARM_PMU_MVE_STALL_RESOURCE   0x02CD
 Stall cycles caused by an MVE instruction because of resource conflicts. More...
 
#define ARM_PMU_MVE_STALL_RESOURCE_MEM   0x02CE
 Stall cycles caused by an MVE instruction because of memory resource conflicts. More...
 
#define ARM_PMU_MVE_STALL_RESOURCE_FP   0x02CF
 Stall cycles caused by an MVE instruction because of floating-point resource conflicts. More...
 
#define ARM_PMU_MVE_STALL_RESOURCE_INT   0x02D0
 Stall cycles caused by an MVE instruction because of integer resource conflicts. More...
 
#define ARM_PMU_MVE_STALL_BREAK   0x02D3
 Stall cycles caused by an MVE chain break. More...
 
#define ARM_PMU_MVE_STALL_DEPENDENCY   0x02D4
 Stall cycles caused by MVE register dependency. More...
 
#define ARM_PMU_ITCM_ACCESS   0x4007
 Instruction TCM access. More...
 
#define ARM_PMU_DTCM_ACCESS   0x4008
 Data TCM access. More...
 
#define ARM_PMU_TRCEXTOUT0   0x4010
 ETM external output 0. More...
 
#define ARM_PMU_TRCEXTOUT1   0x4011
 ETM external output 1. More...
 
#define ARM_PMU_TRCEXTOUT2   0x4012
 ETM external output 2. More...
 
#define ARM_PMU_TRCEXTOUT3   0x4013
 ETM external output 3. More...
 
#define ARM_PMU_CTI_TRIGOUT4   0x4018
 Cross-trigger Interface output trigger 4. More...
 
#define ARM_PMU_CTI_TRIGOUT5   0x4019
 Cross-trigger Interface output trigger 5. More...
 
#define ARM_PMU_CTI_TRIGOUT6   0x401A
 Cross-trigger Interface output trigger 6. More...
 
#define ARM_PMU_CTI_TRIGOUT7   0x401B
 Cross-trigger Interface output trigger 7. More...
 

Description

IDs for Armv8.1-M architecture defined events.

These events are available on all Armv8.1-M devices including a PMU.

Macro Definition Documentation

#define ARM_PMU_BF_CANCEL   0x0109

Branch future instruction not taken.

#define ARM_PMU_BF_RETIRED   0x0104

Branch future instruction architecturally executed and condition code check pass.

#define ARM_PMU_BF_SPEC   0x0105

Branch future instruction speculatively executed and condition code check pass.

#define ARM_PMU_BR_IMMED_RETIRED   0x000D

Immediate branch architecturally executed.

#define ARM_PMU_BR_MIS_PRED   0x0010

Mispredicted or not predicted branch speculatively executed.

#define ARM_PMU_BR_MIS_PRED_RETIRED   0x0022

Mispredicted branch instruction architecturally executed.

#define ARM_PMU_BR_PRED   0x0012

Predictable branch speculatively executed.

#define ARM_PMU_BR_RETIRED   0x0021

Branch instruction architecturally executed.

#define ARM_PMU_BR_RETURN_RETIRED   0x000E

Function return instruction architecturally executed and the condition code check pass.

#define ARM_PMU_BUS_ACCESS   0x0019

Bus access.

#define ARM_PMU_BUS_CYCLES   0x001D

Bus cycles.

#define ARM_PMU_CHAIN   0x001E

For an odd numbered counter, increment when an overflow occurs on the preceding even-numbered counter on the same PE.

#define ARM_PMU_CPU_CYCLES   0x0011

Cycle.

#define ARM_PMU_CTI_TRIGOUT4   0x4018

Cross-trigger Interface output trigger 4.

#define ARM_PMU_CTI_TRIGOUT5   0x4019

Cross-trigger Interface output trigger 5.

#define ARM_PMU_CTI_TRIGOUT6   0x401A

Cross-trigger Interface output trigger 6.

#define ARM_PMU_CTI_TRIGOUT7   0x401B

Cross-trigger Interface output trigger 7.

#define ARM_PMU_DTCM_ACCESS   0x4008

Data TCM access.

#define ARM_PMU_DWT_CMPMATCH0   0x0118

DWT comparator 0 match.

#define ARM_PMU_DWT_CMPMATCH1   0x0119

DWT comparator 1 match.

#define ARM_PMU_DWT_CMPMATCH2   0x011A

DWT comparator 2 match.

#define ARM_PMU_DWT_CMPMATCH3   0x011B

DWT comparator 3 match.

#define ARM_PMU_EXC_RETURN   0x000A

Exception return instruction architecturally executed and the condition code check pass.

#define ARM_PMU_EXC_TAKEN   0x0009

Exception entry.

#define ARM_PMU_INST_RETIRED   0x0008

Instruction architecturally executed.

#define ARM_PMU_INST_SPEC   0x001B

Instruction speculatively executed.

#define ARM_PMU_ITCM_ACCESS   0x4007

Instruction TCM access.

#define ARM_PMU_L1D_CACHE   0x0004

L1 D-Cache access.

#define ARM_PMU_L1D_CACHE_ALLOCATE   0x001F

Level 1 data cache allocation without refill.

#define ARM_PMU_L1D_CACHE_MISS_RD   0x0039

Level 1 data cache read miss.

#define ARM_PMU_L1D_CACHE_RD   0x0040

Level 1 data cache read.

#define ARM_PMU_L1D_CACHE_REFILL   0x0003

L1 D-Cache refill.

#define ARM_PMU_L1D_CACHE_WB   0x0015

Level 1 data cache write-back.

#define ARM_PMU_L1I_CACHE   0x0014

Level 1 instruction cache access.

#define ARM_PMU_L1I_CACHE_REFILL   0x0001

L1 I-Cache refill.

#define ARM_PMU_L2D_CACHE   0x0016

Level 2 data cache access.

#define ARM_PMU_L2D_CACHE_ALLOCATE   0x0020

Level 2 data cache allocation without refill.

#define ARM_PMU_L2D_CACHE_REFILL   0x0017

Level 2 data cache refill.

#define ARM_PMU_L2D_CACHE_WB   0x0018

Level 2 data cache write-back.

#define ARM_PMU_L2I_CACHE   0x0027

Level 2 instruction cache access.

#define ARM_PMU_L2I_CACHE_REFILL   0x0028

Level 2 instruction cache refill.

#define ARM_PMU_L3D_CACHE   0x002B

Level 3 data cache access.

#define ARM_PMU_L3D_CACHE_ALLOCATE   0x0029

Level 3 data cache allocation without refill.

#define ARM_PMU_L3D_CACHE_REFILL   0x002A

Level 3 data cache refill.

#define ARM_PMU_L3D_CACHE_WB   0x002C

Level 3 data cache write-back.

#define ARM_PMU_LD_RETIRED   0x0006

Memory-reading instruction architecturally executed and condition code check pass.

#define ARM_PMU_LE_CANCEL   0x0108

Loop end instruction not taken.

#define ARM_PMU_LE_RETIRED   0x0100

Loop end instruction executed.

#define ARM_PMU_LE_SPEC   0x0101

Loop end instruction speculatively executed.

#define ARM_PMU_LL_CACHE_MISS_RD   0x0037

Last level data cache read miss.

#define ARM_PMU_LL_CACHE_RD   0x0036

Last level data cache read.

#define ARM_PMU_MEM_ACCESS   0x0013

Data memory access.

#define ARM_PMU_MEMORY_ERROR   0x001A

Local memory error.

#define ARM_PMU_MVE_FP_HP_RETIRED   0x0208

MVE half-precision floating-point instruction architecturally executed.

#define ARM_PMU_MVE_FP_HP_SPEC   0x0209

MVE half-precision floating-point instruction speculatively executed.

#define ARM_PMU_MVE_FP_MAC_RETIRED   0x0214

MVE floating-point multiply or multiply-accumulate instruction architecturally executed.

#define ARM_PMU_MVE_FP_MAC_SPEC   0x0215

MVE floating-point multiply or multiply-accumulate instruction speculatively executed.

#define ARM_PMU_MVE_FP_RETIRED   0x0204

MVE floating-point instruction architecturally executed.

#define ARM_PMU_MVE_FP_SP_RETIRED   0x020C

MVE single-precision floating-point instruction architecturally executed.

#define ARM_PMU_MVE_FP_SP_SPEC   0x020D

MVE single-precision floating-point instruction speculatively executed.

#define ARM_PMU_MVE_FP_SPEC   0x0205

MVE floating-point instruction speculatively executed.

#define ARM_PMU_MVE_INST_RETIRED   0x0200

MVE instruction architecturally executed.

#define ARM_PMU_MVE_INST_SPEC   0x0201

MVE instruction speculatively executed.

#define ARM_PMU_MVE_INT_MAC_RETIRED   0x0228

MVE multiply or multiply-accumulate instruction architecturally executed.

#define ARM_PMU_MVE_INT_MAC_SPEC   0x0229

MVE multiply or multiply-accumulate instruction speculatively executed.

#define ARM_PMU_MVE_INT_RETIRED   0x0224

MVE integer instruction architecturally executed.

#define ARM_PMU_MVE_INT_SPEC   0x0225

MVE integer instruction speculatively executed.

#define ARM_PMU_MVE_LD_CONTIG_RETIRED   0x0248

MVE contiguous load instruction architecturally executed.

#define ARM_PMU_MVE_LD_CONTIG_SPEC   0x0249

MVE contiguous load instruction speculatively executed.

#define ARM_PMU_MVE_LD_MULTI_RETIRED   0x0260

MVE memory load instruction targeting multiple registers architecturally executed.

#define ARM_PMU_MVE_LD_MULTI_SPEC   0x0261

MVE memory load instruction targeting multiple registers speculatively executed.

#define ARM_PMU_MVE_LD_NONCONTIG_RETIRED   0x0254

MVE non-contiguous load instruction architecturally executed.

#define ARM_PMU_MVE_LD_NONCONTIG_SPEC   0x0255

MVE non-contiguous load instruction speculatively executed.

#define ARM_PMU_MVE_LD_RETIRED   0x023C

MVE load instruction architecturally executed.

#define ARM_PMU_MVE_LD_SPEC   0x023D

MVE load instruction speculatively executed.

#define ARM_PMU_MVE_LD_UNALIGNED_RETIRED   0x0290

MVE unaligned load instruction architecturally executed.

#define ARM_PMU_MVE_LD_UNALIGNED_SPEC   0x0291

MVE unaligned load instruction speculatively executed.

#define ARM_PMU_MVE_LDST_CONTIG_RETIRED   0x0244

MVE contiguous load or store instruction architecturally executed.

#define ARM_PMU_MVE_LDST_CONTIG_SPEC   0x0245

MVE contiguous load or store instruction speculatively executed.

#define ARM_PMU_MVE_LDST_MULTI_RETIRED   0x025C

MVE memory instruction targeting multiple registers architecturally executed.

#define ARM_PMU_MVE_LDST_MULTI_SPEC   0x025D

MVE memory instruction targeting multiple registers speculatively executed.

#define ARM_PMU_MVE_LDST_NONCONTIG_RETIRED   0x0250

MVE non-contiguous load or store instruction architecturally executed.

#define ARM_PMU_MVE_LDST_NONCONTIG_SPEC   0x0251

MVE non-contiguous load or store instruction speculatively executed.

#define ARM_PMU_MVE_LDST_RETIRED   0x0238

MVE load or store instruction architecturally executed.

#define ARM_PMU_MVE_LDST_SPEC   0x0239

MVE load or store instruction speculatively executed.

#define ARM_PMU_MVE_LDST_UNALIGNED_NONCONTIG_RETIRED   0x0298

MVE unaligned noncontiguous load or store instruction architecturally executed.

#define ARM_PMU_MVE_LDST_UNALIGNED_NONCONTIG_SPEC   0x0299

MVE unaligned noncontiguous load or store instruction speculatively executed.

#define ARM_PMU_MVE_LDST_UNALIGNED_RETIRED   0x028C

MVE unaligned memory load or store instruction architecturally executed.

#define ARM_PMU_MVE_LDST_UNALIGNED_SPEC   0x028D

MVE unaligned memory load or store instruction speculatively executed.

#define ARM_PMU_MVE_PRED   0x02B8

Cycles where one or more predicated beats architecturally executed.

#define ARM_PMU_MVE_ST_CONTIG_RETIRED   0x024C

MVE contiguous store instruction architecturally executed.

#define ARM_PMU_MVE_ST_CONTIG_SPEC   0x024D

MVE contiguous store instruction speculatively executed.

#define ARM_PMU_MVE_ST_MULTI_RETIRED   0x0261

MVE memory store instruction targeting multiple registers architecturally executed.

#define ARM_PMU_MVE_ST_MULTI_SPEC   0x0265

MVE memory store instruction targeting multiple registers speculatively executed.

#define ARM_PMU_MVE_ST_NONCONTIG_RETIRED   0x0258

MVE non-contiguous store instruction architecturally executed.

#define ARM_PMU_MVE_ST_NONCONTIG_SPEC   0x0259

MVE non-contiguous store instruction speculatively executed.

#define ARM_PMU_MVE_ST_RETIRED   0x0240

MVE store instruction architecturally executed.

#define ARM_PMU_MVE_ST_SPEC   0x0241

MVE store instruction speculatively executed.

#define ARM_PMU_MVE_ST_UNALIGNED_RETIRED   0x0294

MVE unaligned store instruction architecturally executed.

#define ARM_PMU_MVE_ST_UNALIGNED_SPEC   0x0295

MVE unaligned store instruction speculatively executed.

#define ARM_PMU_MVE_STALL   0x02CC

Stall cycles caused by an MVE instruction.

#define ARM_PMU_MVE_STALL_BREAK   0x02D3

Stall cycles caused by an MVE chain break.

#define ARM_PMU_MVE_STALL_DEPENDENCY   0x02D4

Stall cycles caused by MVE register dependency.

#define ARM_PMU_MVE_STALL_RESOURCE   0x02CD

Stall cycles caused by an MVE instruction because of resource conflicts.

#define ARM_PMU_MVE_STALL_RESOURCE_FP   0x02CF

Stall cycles caused by an MVE instruction because of floating-point resource conflicts.

#define ARM_PMU_MVE_STALL_RESOURCE_INT   0x02D0

Stall cycles caused by an MVE instruction because of integer resource conflicts.

#define ARM_PMU_MVE_STALL_RESOURCE_MEM   0x02CE

Stall cycles caused by an MVE instruction because of memory resource conflicts.

#define ARM_PMU_MVE_VREDUCE_FP_RETIRED   0x02A4

MVE floating-point vector reduction instruction architecturally executed.

#define ARM_PMU_MVE_VREDUCE_FP_SPEC   0x02A5

MVE floating-point vector reduction instruction speculatively executed.

#define ARM_PMU_MVE_VREDUCE_INT_RETIRED   0x02A8

MVE integer vector reduction instruction architecturally executed.

#define ARM_PMU_MVE_VREDUCE_INT_SPEC   0x02A9

MVE integer vector reduction instruction speculatively executed.

#define ARM_PMU_MVE_VREDUCE_RETIRED   0x02A0

MVE vector reduction instruction architecturally executed.

#define ARM_PMU_MVE_VREDUCE_SPEC   0x02A1

MVE vector reduction instruction speculatively executed.

#define ARM_PMU_OP_COMPLETE   0x003A

Operation retired.

#define ARM_PMU_OP_SPEC   0x003B

Operation speculatively executed.

#define ARM_PMU_PC_WRITE_RETIRED   0x000C

Software change to the Program Counter (PC). Instruction is architecturally executed and condition code check pass.

#define ARM_PMU_SE_CALL_NS   0x0115

Call to non-secure function, resulting in Security state change.

#define ARM_PMU_SE_CALL_S   0x0114

Call to secure function, resulting in Security state change.

#define ARM_PMU_ST_RETIRED   0x0007

Memory-writing instruction architecturally executed and condition code check pass.

#define ARM_PMU_STALL   0x003C

Stall cycle for instruction or operation not sent for execution.

#define ARM_PMU_STALL_BACKEND   0x0024

No operation issued because of the backend.

#define ARM_PMU_STALL_FRONTEND   0x0023

No operation issued because of the frontend.

#define ARM_PMU_STALL_OP   0x003F

Instruction or operation slots not occupied each cycle.

#define ARM_PMU_STALL_OP_BACKEND   0x003D

Stall cycle for instruction or operation not sent for execution due to pipeline backend.

#define ARM_PMU_STALL_OP_FRONTEND   0x003E

Stall cycle for instruction or operation not sent for execution due to pipeline frontend.

#define ARM_PMU_SW_INCR   0x0000

Software update to the PMU_SWINC register, architecturally executed and condition code check pass.

#define ARM_PMU_TRCEXTOUT0   0x4010

ETM external output 0.

#define ARM_PMU_TRCEXTOUT1   0x4011

ETM external output 1.

#define ARM_PMU_TRCEXTOUT2   0x4012

ETM external output 2.

#define ARM_PMU_TRCEXTOUT3   0x4013

ETM external output 3.

#define ARM_PMU_UNALIGNED_LDST_RETIRED   0x000F

Unaligned memory memory-reading or memory-writing instruction architecturally executed and condition code check pass.