# PMSDSFR\_EL1, Sampling Data Source Filter Register

The PMSDSFR EL1 characteristics are:

# **Purpose**

Controls sample filtering by Data Source.

# **Configuration**

This register is present only when FEAT\_SPE\_FDS is implemented. Otherwise, direct accesses to PMSDSFR\_EL1 are undefined.

#### **Attributes**

PMSDSFR 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   |
|-------------|----------------|------------|------------|------------|------------------|--------------------|------------|------|------------|------------|------------|-----|---------|--------------|------------|------------|------------|------------|------------|------------|------------|------------|-----|------|
| <b>S6</b> 3 | <del>562</del> | <b>S61</b> | S60        | <b>S59</b> | S58 <sup>1</sup> | S57                | <b>S56</b> | S55  | <b>S54</b> | <b>S53</b> | <b>S52</b> | S51 | .S50    | <b>S49</b>   | <b>S48</b> | <b>S47</b> | <b>S46</b> | <b>S45</b> | <b>S44</b> | <b>S43</b> | <b>S42</b> | <b>S41</b> | S40 | S39S |
| S31         | <b>LS30</b>    | JS29       | <b>S28</b> | S27        | S26'             | 1 <mark>525</mark> | S24        | 523' | S22'       | S21        | 520        | S19 | S18     | <u> 1517</u> | 516        | S15        | 514        | <u>513</u> | 512'       | 511'       | 510'       | 59         | 58  | S7 ! |
|             |                |            |            |            |                  |                    |            |      |            | , — — ,    |            |     | . D T C | D = 7        | <u> </u>   | 0 + 0      | <u> </u>   | <u> </u>   | ·,         | $\sim$     | -          |            |     |      |

#### S<m>, bit [m], for m = 63 to 0 When filtering on Data Source <m> is supported:

S[< m>] is the Data Source filter for implementation defined Data Source < m>.

| S <m></m> | Meaning                          |
|-----------|----------------------------------|
| 0b0       | If PMSFCR_EL1.FDS is 1, do       |
|           | not record load operations that  |
|           | have bits [5:0] of the Data      |
|           | Source packet set to <m>.</m>    |
| 0b1       | Load operations with Data        |
|           | Source <m> are unaffected by</m> |
|           | PMSFCR_EL1.FDS.                  |

The reset behavior of this field is:

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

#### Otherwise:

Reserved, RAZ/WI.

# Accessing PMSDSFR\_EL1

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

# MRS <Xt>, PMSDSFR\_EL1

| op0  | op1   | CRn    | CRm    | op2   |  |  |
|------|-------|--------|--------|-------|--|--|
| 0b11 | 0b000 | 0b1001 | 0b1010 | 0b100 |  |  |

```
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'" && MDCR_EL3.EnPMS3 == '0' then
        UNDEFINED;
    elsif Halted() && HaveEL(EL3) && EDSCR.SDD ==
'1' && boolean IMPLEMENTATION_DEFINED "EL3 trap
priority when SDD == '1'" && (MDCR_EL3.NSPB[0] ==
'0' | MDCR_EL3.NSPB[1] != SCR_EL3.NS |
(IsFeatureImplemented(FEAT RME) && MDCR EL3.NSPBE !=
SCR_EL3.NSE)) then
        UNDEFINED;
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT2) && HaveEL(EL3) &&
SCR_EL3.FGTEn2 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT2) &&
HDFGRTR2_EL2.nPMSDSFR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && MDCR_EL2.TPMS == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && MDCR_EL3.EnPMS3 == '0' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    elsif HaveEL(EL3) && (MDCR_EL3.NSPB[0] == '0' |
MDCR_EL3.NSPB[1] != SCR_EL3.NS |
(IsFeatureImplemented(FEAT_RME) && MDCR_EL3.NSPBE !=
SCR_EL3.NSE)) then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    elsif EL2Enabled() && HCR_EL2.<NV2,NV> == '11'
```

```
then
        X[t, 64] = NVMem[0x858];
    else
        X[t, 64] = PMSDSFR\_EL1;
elsif PSTATE.EL == EL2 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && (MDCR_EL3.NSPB[0] == '0' |
MDCR_EL3.NSPB[1] != SCR_EL3.NS |
(IsFeatureImplemented(FEAT RME) && MDCR EL3.NSPBE !=
SCR_EL3.NSE)) then
        UNDEFINED;
    elsif Halted() && HaveEL(EL3) && EDSCR.SDD ==
'1' && boolean IMPLEMENTATION DEFINED "EL3 trap
priority when SDD == '1'" && MDCR_EL3.EnPMS3 == '0'
then
        UNDEFINED;
    elsif HaveEL(EL3) && (MDCR_EL3.NSPB[0] == '0' |
MDCR_EL3.NSPB[1] != SCR_EL3.NS ||
(IsFeatureImplemented(FEAT RME) && MDCR EL3.NSPBE !=
SCR EL3.NSE)) then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    elsif HaveEL(EL3) && MDCR_EL3.EnPMS3 == '0' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED:
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = PMSDSFR\_EL1;
elsif PSTATE.EL == EL3 then
    X[t, 64] = PMSDSFR\_EL1;
```

# MSR PMSDSFR EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |  |  |
|------|-------|--------|--------|-------|--|--|
| 0b11 | 0b000 | 0b1001 | 0b1010 | 0b100 |  |  |

```
UNDEFINED;
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT2) && HaveEL(EL3) &&
SCR_EL3.FGTEn2 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT2) &&
HDFGWTR2_EL2.nPMSDSFR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && MDCR EL2.TPMS == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && MDCR EL3.EnPMS3 == '0' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED:
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    elsif HaveEL(EL3) && (MDCR_EL3.NSPB[0] == '0' |
MDCR_EL3.NSPB[1] != SCR_EL3.NS |
(IsFeatureImplemented(FEAT RME) && MDCR EL3.NSPBE !=
SCR EL3.NSE)) then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    elsif EL2Enabled() && HCR_EL2.<NV2,NV> == '11'
then
        NVMem[0x858] = X[t, 64];
        PMSDSFR EL1 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && (MDCR_EL3.NSPB[0] == '0' |
MDCR_EL3.NSPB[1] != SCR_EL3.NS |
(IsFeatureImplemented(FEAT_RME) && MDCR_EL3.NSPBE !=
SCR_EL3.NSE)) then
        UNDEFINED;
    elsif Halted() && HaveEL(EL3) && EDSCR.SDD ==
'1' && boolean IMPLEMENTATION_DEFINED "EL3 trap
priority when SDD == '1'" && MDCR_EL3.EnPMS3 == '0'
then
        UNDEFINED;
    elsif HaveEL(EL3) && (MDCR_EL3.NSPB[0] == '0' |
MDCR_EL3.NSPB[1] != SCR_EL3.NS |
(IsFeatureImplemented(FEAT_RME) && MDCR_EL3.NSPBE !=
SCR_EL3.NSE)) then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
            AArch64.SystemAccessTrap(EL3, 0x18);
    elsif HaveEL(EL3) && MDCR_EL3.EnPMS3 == '0' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
        PMSDSFR\_EL1 = X[t, 64];
elsif PSTATE.EL == EL3 then
    PMSDSFR\_EL1 = X[t, 64];
```

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

Copyright  $\hat{A}$  © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.