AArch64
Instructions

Index by Encoding

External Registers

# PMLSR, Performance Monitors Lock Status Register

The PMLSR characteristics are:

## **Purpose**

Indicates the current status of the software lock for Performance Monitors registers.

The optional Software Lock provides a lock to prevent memory-mapped writes to the Performance Monitors registers. Use of this lock mechanism reduces the risk of accidental damage to the contents of the Performance Monitors registers. It does not, and cannot, prevent all accidental or malicious damage.

## **Configuration**

This register is present only when FEAT\_PMUv3\_EXT32 is implemented. Otherwise, direct accesses to PMLSR are res0.

If FEAT\_DoPD is implemented, Software Lock is not implemented by the architecturally-defined debug components of the PE in the Core power domain.

If FEAT\_DoPD is not implemented, this register is in the Debug power domain.

Software uses PMU.PMLAR to set or clear the lock, and PMLSR to check the current status of the lock.

### **Attributes**

PMLSR is a 32-bit register.

This register is part of the **PMU** block.

## **Field descriptions**

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

RESO nTSL SL

#### Bits [31:3]

Reserved, res0.

### nTT, bit [2]

Not thirty-two bit access required.

Reads as 0b0.

Access to this field is **RO**.

### **SLK**, bit [1]

### When Software Lock is implemented and FEAT DoPD is not implemented:

Software Lock status for this component. For an access to LSR that is not a memory-mapped access, or when Software Lock is not implemented, this field is res0.

For memory-mapped accesses when Software Lock is implemented, possible values of this field are:

| SLK | Meaning                             |
|-----|-------------------------------------|
| 0b0 | Lock clear. Writes are permitted to |
|     | this component's registers.         |
| 0b1 | Lock set. Writes to this            |
|     | component's registers are           |
|     | ignored, and reads have no side     |
|     | effects.                            |

The reset behavior of this field is:

• On an External debug reset, this field resets to 1.

#### Otherwise:

Reserved, RAZ.

#### **SLI, bit [0]**

Software Lock implemented. For an access to LSR that is not a memory-mapped access, this field is RAZ. For memory-mapped accesses, the value of this field is implementation defined. Permitted values are:

| SLI | Meaning                          |
|-----|----------------------------------|
| 0b0 | Software Lock not implemented or |
|     | not memory-mapped access.        |
| 0b1 | Software Lock implemented and    |
|     | memory-mapped access.            |

## **Accessing PMLSR**

Accesses to this register use the following encodings:

# Accessible at offset 0xFB4 from PMU

- When FEAT\_DoPD is implemented and !IsCorePowered(), accesses to this register generate an error response.
- Otherwise, accesses to this register are **RO**.

AArch32 Registers AArch64 Registers AArch32 Instructions AArch64
Instructions

Index by Encoding External Registers

 $28/03/2023\ 16:01;\ 72747e43966d6b97dcbd230a1b3f0421d1ea3d94$ 

Copyright © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.