This is a list of all ARM V7 Cortex-A15's performance counter event types. See Cortex-A15 MPCore Technical Reference Manual Cortex A15 DDI (ARM DDI 0438F, revision r3p1)
Name | Description | Counters usable | Unit mask options |
SW_INCR | Software increment of PMNC registers | 1, 2, 3, 4, 5, 6 | |
L1I_CACHE_REFILL | Level 1 instruction cache refill | 1, 2, 3, 4, 5, 6 | |
L1I_TLB_REFILL | Level 1 instruction TLB refill | 1, 2, 3, 4, 5, 6 | |
L1D_CACHE_REFILL | Level 1 data cache refill | 1, 2, 3, 4, 5, 6 | |
L1D_CACHE | Level 1 data cache access | 1, 2, 3, 4, 5, 6 | |
L1D_TLB_REFILL | Level 1 data TLB refill | 1, 2, 3, 4, 5, 6 | |
LD_RETIRED | Load instruction architecturally executed, condition code pass | 1, 2, 3, 4, 5, 6 | |
ST_RETIRED | Store instruction architecturally executed, condition code pass | 1, 2, 3, 4, 5, 6 | |
INST_RETIRED | Instruction architecturally executed | 1, 2, 3, 4, 5, 6 | |
EXC_TAKEN | Exception taken | 1, 2, 3, 4, 5, 6 | |
EXC_RETURN | Exception return instruction architecturally executed | 1, 2, 3, 4, 5, 6 | |
CID_WRITE_RETIRED | Write to CONTEXTIDR register architecturally executed | 1, 2, 3, 4, 5, 6 | |
PC_WRITE_RETIRED | Software change of the PC architecturally executed, condition code pass | 1, 2, 3, 4, 5, 6 | |
BR_IMMED_RETIRED | Immediate branch instruction architecturally executed | 1, 2, 3, 4, 5, 6 | |
BR_RETURN_RETIRED | Procedure return instruction architecturally executed, condition code pass | 1, 2, 3, 4, 5, 6 | |
UNALIGNED_LDST_RETIRED | Unaligned load or store instruction architecturally executed, condition code pass | 1, 2, 3, 4, 5, 6 | |
BR_MIS_PRED | Mispredicted or not predicted branch speculatively executed | 1, 2, 3, 4, 5, 6 | |
BR_PRED | Predictable branch speculatively executed | 1, 2, 3, 4, 5, 6 | |
MEM_ACCESS | Data memory access | 1, 2, 3, 4, 5, 6 | |
L1I_CACHE | Level 1 instruction cache access | 1, 2, 3, 4, 5, 6 | |
L1D_CACHE_WB | Level 1 data cache write-back | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE | Level 2 data cache access | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE_REFILL | Level 2 data cache refill | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE_WB | Level 2 data cache write-back | 1, 2, 3, 4, 5, 6 | |
BUS_ACCESS | Bus access | 1, 2, 3, 4, 5, 6 | |
MEMORY_ERROR | Local memory error | 1, 2, 3, 4, 5, 6 | |
INST_SPEC | Instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
TTBR_WRITE_RETIRED | Write to TTBR architecturally executed, condition code pass | 1, 2, 3, 4, 5, 6 | |
BUS_CYCLES | Bus cycle | 1, 2, 3, 4, 5, 6 | |
CPU_CYCLES | CPU cycle | 0 | |
L1D_CACHE_LD | Level 1 data cache access, read | 1, 2, 3, 4, 5, 6 | |
L1D_CACHE_ST | Level 1 data cache access, write | 1, 2, 3, 4, 5, 6 | |
L1D_CACHE_REFILL_LD | Level 1 data cache refill, read | 1, 2, 3, 4, 5, 6 | |
L1D_CACHE_REFILL_ST | Level 1 data cache refill, write | 1, 2, 3, 4, 5, 6 | |
L1D_CACHE_WB_VICTIM | Level 1 data cache write-back, victim | 1, 2, 3, 4, 5, 6 | |
L1D_CACHE_WB_CLEAN | Level 1 data cache write-back, cleaning and coherency | 1, 2, 3, 4, 5, 6 | |
L1D_CACHE_INVAL | Level 1 data cache invalidate | 1, 2, 3, 4, 5, 6 | |
L1D_TLB_REFILL_LD | Level 1 data TLB refill, read | 1, 2, 3, 4, 5, 6 | |
L1D_TLB_REFILL_ST | Level 1 data TLB refill, write | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE_LD | Level 2 data cache access, read | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE_ST | Level 2 data cache access, write | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE_REFILL_LD | Level 2 data cache refill, read | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE_REFILL_ST | Level 2 data cache refill, write | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE_WB_VICTIM | Level 2 data cache write-back, victim | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE_WB_CLEAN | Level 2 data cache write-back, cleaning and coherency | 1, 2, 3, 4, 5, 6 | |
L2D_CACHE_INVAL | Level 2 data cache invalidate | 1, 2, 3, 4, 5, 6 | |
BUS_ACCESS_LD | Bus access, read | 1, 2, 3, 4, 5, 6 | |
BUS_ACCESS_ST | Bus access, write | 1, 2, 3, 4, 5, 6 | |
BUS_ACCESS_SHARED | Bus access, normal, cacheable, shareable | 1, 2, 3, 4, 5, 6 | |
BUS_ACCESS_NOT_SHARED | Bus access, not normal, cacheable, shareable | 1, 2, 3, 4, 5, 6 | |
BUS_ACCESS_NORMAL | Bus access, normal | 1, 2, 3, 4, 5, 6 | |
BUS_ACCESS_PERIPH | Bus access, peripheral | 1, 2, 3, 4, 5, 6 | |
MEM_ACCESS_LD | Data memory access, read | 1, 2, 3, 4, 5, 6 | |
MEM_ACCESS_ST | Data memory access, write | 1, 2, 3, 4, 5, 6 | |
UNALIGNED_LD_SPEC | Unaligned access, read | 1, 2, 3, 4, 5, 6 | |
UNALIGNED_ST_SPEC | Unaligned access, write | 1, 2, 3, 4, 5, 6 | |
UNALIGNED_LDST_SPEC | Unaligned access | 1, 2, 3, 4, 5, 6 | |
LDREX_SPEC | ldrex instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
STREX_PASS_SPEC | strex instruction speculatively executed, pass | 1, 2, 3, 4, 5, 6 | |
STREX_FAIL_SPEC | strex instruction speculatively executed, fail | 1, 2, 3, 4, 5, 6 | |
LD_SPEC | Load instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
ST_SPEC | Store instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
LDST_SPEC | Load or store instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
DP_SPEC | Integer data processing instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
ASE_SPEC | Advanced SIMD extension instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
VFP_SPEC | Floating-point extension instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
PC_WRITE_SPEC | Software change of the PC instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
BR_IMMED_SPEC | Immediate branch instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
BR_RETURN_SPEC | Procedure return instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
BR_INDIRECT_SPEC | Indirect branch instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
ISB_SPEC | ISB barrier instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
DSB_SPEC | DSB barrier instruction speculatively executed | 1, 2, 3, 4, 5, 6 | |
DMB_SPEC | DMB barrier instruction speculatively executed | 1, 2, 3, 4, 5, 6 |
Premature optimization is the root of all evil.- Tony Hoare