AArch64
Instructions

Index by Encoding

External Registers

# MVFR2\_EL1, AArch32 Media and VFP Feature Register 2

The MVFR2 EL1 characteristics are:

## **Purpose**

Describes the features provided by the AArch32 Advanced SIMD and Floating-point implementation.

Must be interpreted with MVFR0 EL1 and MVFR1 EL1.

For general information about the interpretation of the ID registers, see 'Principles of the ID scheme for fields in ID registers'.

## **Configuration**

AArch64 System register MVFR2\_EL1 bits [31:0] are architecturally mapped to AArch32 System register MVFR2[31:0].

In an implementation where at least one Exception level supports execution in AArch32 state, but there is no support for Advanced SIMD and floating-point operation, this register is RAZ.

### **Attributes**

MVFR2 EL1 is a 64-bit register.

## Field descriptions

## When AArch32 is supported:

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

| IL50 |        |          |
|------|--------|----------|
| RES0 | FPMisc | SIMDMisc |

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

#### Bits [63:8]

Reserved, res0.

#### FPMisc, bits [7:4]

Indicates whether the floating-point implementation provides support for miscellaneous VFP features.

| FPMisc | Meaning                       |
|--------|-------------------------------|
| 0b0000 | Not implemented, or no        |
|        | support for miscellaneous     |
|        | features.                     |
| 0b0001 | Support for Floating-point    |
|        | selection.                    |
| 0b0010 | As 0b0001, and Floating-point |
|        | Conversion to Integer with    |
|        | Directed Rounding modes.      |
| 0b0011 | As 0b0010, and Floating-point |
|        | Round to Integer Floating-    |
|        | point.                        |
| 0b0100 | As 0b0011, and Floating-point |
|        | MaxNum and MinNum.            |

All other values are reserved.

In Armv8-A, the permitted values are 0b0000 and 0b0100.

## SIMDMisc, bits [3:0]

Indicates whether the Advanced SIMD implementation provides support for miscellaneous Advanced SIMD features.

| SIMDMisc | Meaning                                                               |
|----------|-----------------------------------------------------------------------|
| 000000   | Not implemented, or no support for miscellaneous features.            |
| 0b0001   | Floating-point Conversion to Integer with Directed Rounding modes.    |
| 0b0010   | As 0b0001, and Floating-<br>point Round to Integer<br>Floating-point. |
| 0b0011   | As 0b0010, and Floating-<br>point MaxNum and<br>MinNum.               |

All other values are reserved.

In Armv8-A, the permitted values are 0b0000 and 0b0011.

## Otherwise:

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

|          |            |          |         |        |             |       |    |         |    |               |            |     | <br> |               |               |          | _             |
|----------|------------|----------|---------|--------|-------------|-------|----|---------|----|---------------|------------|-----|------|---------------|---------------|----------|---------------|
|          |            |          |         | U      | <b>NKNO</b> | WN    |    |         |    |               |            |     |      |               |               |          |               |
|          |            |          |         | U      | NKNO        | WN    |    |         |    |               |            |     |      |               |               |          |               |
| 21 20 20 | 20 27 26 2 | <u> </u> | 21 20 1 | 0 10 1 | 7 1 ( 1 [   | 1 / 1 | 17 | 1 2 1 1 | 10 | $\overline{}$ | <u>~ -</u> | 7 ( | <br> | $\overline{}$ | $\overline{}$ | <u> </u> | $\overline{}$ |

#### Bits [63:0]

Reserved, unknown.

## **Accessing MVFR2\_EL1**

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

## MRS <Xt>, MVFR2 EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b000 | 0b0000 | 0b0011 | 0b010 |

```
if PSTATE.EL == ELO then
    if IsFeatureImplemented(FEAT IDST) then
        if EL2Enabled() && HCR_EL2.TGE == '1' then
            AArch64.SystemAccessTrap(EL2, 0x18);
        else
            AArch64.SystemAccessTrap(EL1, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.TID3 == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = MVFR2\_EL1;
elsif PSTATE.EL == EL2 then
    X[t, 64] = MVFR2\_EL1;
elsif PSTATE.EL == EL3 then
    X[t, 64] = MVFR2\_EL1;
```

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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