AArch32 Instructions AArch64
Instructions

Index by Encoding

External Registers

# TRCVIIECTLR, ViewInst Include/Exclude Control Register

The TRCVIIECTLR characteristics are:

## **Purpose**

Use this to select, or read, the Address Range Comparators for the ViewInst include/exclude function.

## **Configuration**

AArch64 System register TRCVIIECTLR bits [31:0] are architecturally mapped to External register TRCVIIECTLR[31:0].

This register is present only when FEAT\_ETE is implemented, FEAT\_TRC\_SR is implemented and UInt(TRCIDR4.NUMACPAIRS) > 0. Otherwise, direct accesses to TRCVIIECTLR are undefined.

### **Attributes**

TRCVIIECTLR is a 64-bit register.

## Field descriptions

| 6362616059585756 | 55        | 54          | 53         | 52         | 51         | 50         | 49       |
|------------------|-----------|-------------|------------|------------|------------|------------|----------|
|                  |           |             |            |            |            |            |          |
| RES0             | EXCLUDE[7 | ]EXCLUDE[6] | EXCLUDE[5] | EXCLUDE[4] | EXCLUDE[3] | EXCLUDE[2] | EXCLUDE[ |
| 3130292827262524 | 23        | 22          | 21         | 20         | 19         | 18         | 17       |

#### Bits [63:24]

Reserved, res0.

#### EXCLUDE[< m >], bit [m+16], for m = 7 to 0

Exclude Address Range Comparator <m>. Selects whether Address Range Comparator <m> is in use with the ViewInst exclude function.

| EXCLUDE[ <m>]</m> | Meaning |  |
|-------------------|---------|--|
|                   |         |  |

| 0d0 | The address range    |
|-----|----------------------|
|     | that Address Range   |
|     | Comparator <m></m>   |
|     | defines, is not      |
|     | selected for the     |
|     | ViewInst exclude     |
|     | function.            |
| 0b1 | The address range    |
|     | that Address Range   |
|     | Comparator <m></m>   |
|     | defines, is selected |
|     | for the ViewInst     |
|     | exclude function.    |

This bit is res0 if  $m \ge TRCIDR4$ .NUMACPAIRS.

The reset behavior of this field is:

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

#### Bits [15:8]

Reserved, res0.

#### INCLUDE[< m>], bit [m], for m = 7 to 0

Include Address Range Comparator <m>.

Selects whether Address Range Comparator <m> is in use with the ViewInst include function.

Selecting no comparators for the ViewInst include function indicates that all instructions are included by default.

The ViewInst exclude function then indicates which ranges are excluded.

| INCLUDE[ <m>]</m> | Meaning              |  |  |
|-------------------|----------------------|--|--|
| 0b0               | The address range    |  |  |
|                   | that Address Range   |  |  |
|                   | Comparator <m></m>   |  |  |
|                   | defines, is not      |  |  |
|                   | selected for the     |  |  |
|                   | ViewInst include     |  |  |
|                   | function.            |  |  |
| 0b1               | The address range    |  |  |
|                   | that Address Range   |  |  |
|                   | Comparator <m></m>   |  |  |
|                   | defines, is selected |  |  |
|                   | for the ViewInst     |  |  |
|                   | include function.    |  |  |

This bit is res0 if  $m \ge TRCIDR4.NUMACPAIRS$ .

The reset behavior of this field is:

 On a Trace unit reset, this field resets to an architecturally unknown value.

## **Accessing TRCVIIECTLR**

Must be programmed if TRCIDR4.NUMACPAIRS > 0b0000.

Writes are constrained unpredictable if the trace unit is not in the Idle state.

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

## MRS <Xt>, TRCVIIECTLR

| op0  | op1   | CRn    | CRm    | op2   |  |
|------|-------|--------|--------|-------|--|
| 0b10 | 0b001 | 0b0000 | 0b0001 | 0b010 |  |

```
if PSTATE.EL == ELO then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && CPTR EL3.TTA == '1' then
       UNDEFINED;
    elsif CPACR EL1.TTA == '1' then
        AArch64.SystemAccessTrap(EL1, 0x18);
    elsif EL2Enabled() && CPTR_EL2.TTA == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT FGT) && (!HaveEL(EL3) | |
SCR EL3.FGTEn == '1') && HDFGRTR EL2.TRC == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && CPTR EL3.TTA == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = TRCVIIECTLR;
elsif PSTATE.EL == EL2 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && CPTR EL3.TTA == '1' then
        UNDEFINED;
    elsif CPTR_EL2.TTA == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && CPTR_EL3.TTA == '1' then
```

## MSR TRCVIIECTLR, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b10 | 0b001 | 0b0000 | 0b0001 | 0b010 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && CPTR EL3.TTA == '1' then
        UNDEFINED;
    elsif CPACR_EL1.TTA == '1' then
        AArch64.SystemAccessTrap(EL1, 0x18);
    elsif EL2Enabled() && CPTR_EL2.TTA == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3) | |
SCR_EL3.FGTEn == '1') && HDFGWTR_EL2.TRC == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && CPTR_EL3.TTA == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        TRCVIIECTLR = X[t, 64];
elsif PSTATE.EL == EL2 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && CPTR_EL3.TTA == '1' then
        UNDEFINED;
    elsif CPTR_EL2.TTA == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && CPTR_EL3.TTA == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        TRCVIIECTLR = X[t, 64];
```

```
elsif PSTATE.EL == EL3 then
  if CPTR_EL3.TTA == '1' then
     AArch64.SystemAccessTrap(EL3, 0x18);
else
     TRCVIIECTLR = X[t, 64];
```

AArch32 Registers AArch64 Registers AArch32 Instructions AArch64 Instructions Index by Encoding External Registers

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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