AArch64 Instructions Index by Encoding

External Registers

# CNTPS\_CVAL\_EL1, Counter-timer Physical Secure Timer CompareValue Register

The CNTPS CVAL EL1 characteristics are:

#### **Purpose**

Holds the compare value for the secure physical timer, usually accessible at EL3 but configurably accessible at EL1 in Secure state.

## **Configuration**

This register is present only when EL3 is implemented. Otherwise, direct accesses to CNTPS CVAL EL1 are undefined.

#### **Attributes**

CNTPS CVAL EL1 is a 64-bit register.

#### Field descriptions

63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32

CompareValue

CompareValue

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

#### CompareValue, bits [63:0]

Holds the secure physical timer CompareValue.

When <u>CNTPS\_CTL\_EL1</u>.ENABLE is 1, the timer condition is met when (<u>CNTPCT\_EL0</u> - CompareValue) is greater than or equal to zero. This means that CompareValue acts like a 64-bit upcounter timer. When the timer condition is met:

- CNTPS CTL EL1.ISTATUS is set to 1.
- If <u>CNTPS\_CTL\_EL1</u>.IMASK is 0, an interrupt is generated.

When <u>CNTPS\_CTL\_EL1</u>.ENABLE is 0, the timer condition is not met, but <u>CNTPCT\_EL0</u> continues to count.

If the Generic counter is implemented at a size less than 64 bits, then this field is permitted to be implemented at the same width as the counter, and the upper bits are res0.

The value of this field is treated as zero-extended in all counter calculations.

The reset behavior of this field is:

• On a Warm reset, this field resets to an architecturally unknown value.

### Accessing CNTPS\_CVAL\_EL1

Accesses to this register use the following encodings in the System register encoding space:

## MRS <Xt>, CNTPS\_CVAL\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b111 | 0b1110 | 0b0010 | 0b010 |

# MSR CNTPS\_CVAL\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b111 | 0b1110 | 0b0010 | 0b010 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if HaveEL(EL3) && SCR_EL3.NS == '0' then
        if SCR_EL3.EEL2 == '1' then
```

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.