# ERR<n>PFGF, Error Record <n> Pseudo-fault Generation Feature Register, n = 0 - 65534

The ERR<n>PFGF characteristics are:

# **Purpose**

Defines which common architecturally-defined fault generation features are implemented.

# **Configuration**

This register is present only when error record <n> is implemented, the node implements the Common Fault Injection Model Extension (ERR<n>FR.INJ != 0b00) and error record <n> is the first error record owned by a node. Otherwise, direct accesses to ERR<n>PFGF are res0.

ERR<n>FR describes the features implemented by the node.

# **Attributes**

ERR<n>PFGF is a 64-bit register.

# Field descriptions

| 63  | 62 61 | L 6 | 0 595857565554535251504948474645 | 44 | 43 | 42 | 414 | 039  | 38 | 37 | 36  | 35  | 34  | 33 | 32             |
|-----|-------|-----|----------------------------------|----|----|----|-----|------|----|----|-----|-----|-----|----|----------------|
|     |       |     | RES0                             |    |    |    |     |      |    |    |     |     |     |    |                |
| RES | RSY   | NN. | RESO I                           | ΜV | 4V | PN | ERC | CI C | ΕŒ | DΕ | UEO | UER | UEU | UC | OF             |
| 31  | 30.20 | ) 2 | 3 272625242322212019181716151413 | 12 | 11 | 10 | 9 8 | 3 7  | 6  | 5  | 4   | 3   | 2   | 1  | $\overline{0}$ |

#### Bits [63:31]

Reserved, res0.

# R, bit [30]

Restartable. Support for Error Generation Counter restart mode.

| R   | Meaning                                                |
|-----|--------------------------------------------------------|
| 0b0 | The node does not support this feature.                |
|     | ERR <n>PFGCTL.R is res0.</n>                           |
| 0b1 | Error Generation Counter restart mode is               |
|     | implemented and is controlled by                       |
|     | <u>ERR<n>PFGCTL</n></u> .R. <u>ERR<n>PFGCTL</n></u> .R |
|     | is a read/write field.                                 |

### **SYN, bit [29]**

Syndrome. Fault syndrome injection.

| SYN | Meaning                                   |
|-----|-------------------------------------------|
| 0b0 | When an injected error is                 |
|     | recorded, the node sets                   |
|     | <pre>ERR<n>STATUS.{IERR, SERR}</n></pre>  |
|     | to implementation defined values.         |
|     | <pre>ERR<n>STATUS.{IERR, SERR}</n></pre>  |
|     | are unknown when                          |
|     | ERR <n>STATUS.V is 0.</n>                 |
| 0b1 | When an injected error is                 |
|     | recorded, the node does not               |
|     | update the <u>ERR<n>STATUS</n></u> .      |
|     | {IERR, SERR} fields.                      |
|     | <pre>ERR<n>STATUS. {IERR, SERR}</n></pre> |
|     | are writable when                         |
|     | ERR < n > STATUS. V is 0.                 |

#### **Note**

If ERR<n>PFGF.SYN is 1 then software can write specific values into the <u>ERR<n>STATUS</u>.{IERR, SERR} fields when setting up a fault injection event. The sets of values that can be written to these fields is implementation defined.

### NA, bit [28]

No access required. Defines whether this component fakes detection of the error on an access to the component or spontaneously in the fault injection state.

| NA  | Meaning                              |
|-----|--------------------------------------|
| 0b0 | The component fakes detection of     |
|     | the error on an access to the        |
|     | component.                           |
| 0b1 | The component fakes detection of     |
|     | the error spontaneously in the fault |
|     | injection state.                     |

### Bits [27:13]

Reserved, res0.

# MV, bit [12]

Miscellaneous syndrome.

Defines whether software can control all or part of the syndrome recorded in the ERR<n>MISC<m> registers when an injected error is recorded.

It is implementation defined which ERR<n>MISC<m> syndrome fields, if any, are updated by the node when an injected error is recorded. Some syndrome fields might always be updated by the node when an error, including an injected error, is recorded. For example, a corrected error counter might always be updated when any countable error, including a injected countable error, is recorded.

# MV Meaning

When an injected error is recorded, the node might update the ERR<n>MISC<m> registers:

- If any syndrome is recorded by the node in the ERR<n>MISC<m> registers, then <u>ERR<n>STATUS</u>.MV is set to 1.
- Otherwise, <u>ERR<n>STATUS</u>.MV is unchanged.

If the node always sets <u>ERR<n>STATUS</u>.MV to 1 when recording an injected error then <u>ERR<n>PFGCTL</u>.MV might be RAO/WI. Otherwise <u>ERR<n>PFGCTL</u>.MV is res0.

- When an injected error is recorded, the node might update some, but not all ERR<n>MISC<m> syndrome fields:
  - If any syndrome is recorded by the node in the ERR<n>MISC<m> registers, then <u>ERR<n>STATUS</u>.MV is set to 1.
  - Otherwise, <u>ERR<n>STATUS</u>.MV is set to <u>ERR<n>PFGCTL.MV</u>.

ERR<n>MISC<m> syndrome fields that are not updated by the node are writable when <u>ERR<n>STATUS</u>.MV is 0.

If the node always sets <u>ERR<n>STATUS</u>.MV to 1 when recording an injected error then <u>ERR<n>PFGCTL</u>.MV is RAO/WI. Otherwise <u>ERR<n>PFGCTL</u>.MV is a read/write field.

If ERR<n>PFGF.MV is 1, software can write specific additional syndrome values into the ERR<n>MISC<m> registers when setting up a fault injection event. The permitted values that can be written to these registers are implementation defined.

# **AV, bit [11]**

Address syndrome. Defines whether software can control the address recorded in <u>ERR<n>ADDR</u> when an injected error is recorded.

| AV  | Meaning                                                  |
|-----|----------------------------------------------------------|
| 0b0 | When an injected error is recorded, the node             |
|     | might record an address in <u>ERR<n>ADDR</n></u> . If an |
|     | address is recorded in <u>ERR<n>ADDR</n></u> , then      |
|     | ERR <n>STATUS.AV is set to 1. Otherwise,</n>             |
|     | ERR <n>ADDR and ERR<n>STATUS.AV are</n></n>              |
|     | unchanged.                                               |
|     | If the node always records an address and sets           |
|     | ERR <n>STATUS.AV to 1 when recording an</n>              |
|     | injected error then <u>ERR<n>PFGCTL</n></u> .AV might be |
|     | RAO/WI. Otherwise <u>ERR<n>PFGCTL</n></u> .AV is res0.   |

- When an injected error is recorded, the node does not update <u>ERR<n>ADDR</u> and does one of:
  - Sets <u>ERR<n>STATUS</u>.AV to <u>ERR<n>PFGCTL</u>.AV. <u>ERR<n>PFGCTL</u>.AV is a read/write field.
  - Sets <u>ERR<n>STATUS</u>.AV to 1. ERR<n>PFGCTL.AV is RAO/WI.

<u>ERR<n>ADDR</u> is writable when ERR<n>STATUS.AV is 0.

If ERR<n>PFGF.AV is 1 then software can write a specific address value into <u>ERR<n>ADDR</u> when setting up a fault injection event.

# PN, bit [10] When the node supports this flag:

Poison flag. Describes how the fault generation feature of the node sets the <u>ERR<n>STATUS</u>.PN status flag.

| PN  | Meaning                                   |
|-----|-------------------------------------------|
| 0b0 | When an injected error is recorded, it is |
|     | implementation defined whether the node   |
|     | sets <u>ERR<n>STATUS</n></u> .PN to 1.    |
|     | <u>ERR<n>PFGCTL</n></u> .PN is res0.      |
| 0b1 | When an injected error is recorded,       |
|     | ERR <n>STATUS.PN is set to</n>            |
|     | ERR <n>PFGCTL.PN. ERR<n>PFGCTL.PN</n></n> |
|     | is a read/write field.                    |

This behavior replaces the architecture-defined rules for setting the ERR<n>STATUS.PN bit.

#### Otherwise:

Reserved, RAZ.

# ER, bit [9]

#### When the node supports this flag:

Error Reported flag. Describes how the fault generation feature of the node sets the <u>ERR<n>STATUS</u>.ER status flag.

| ER  | Meaning                                     |
|-----|---------------------------------------------|
| 0b0 | When an injected error is recorded,         |
|     | the node sets <u>ERR<n>STATUS</n></u> .ER   |
|     | according to the architecture-              |
|     | defined rules for setting the ER            |
|     | field. <u>ERR<n>PFGCTL</n></u> .ER is res0. |

| 0b1 | When an injected error is recorded, |
|-----|-------------------------------------|
|     | ERR <n>STATUS.ER is set to</n>      |
|     | ERR <n>PFGCTL.ER. This behavior</n> |
|     | replaces the architecture-defined   |
|     | rules for setting the ER bit.       |
|     | ERR <n>PFGCTL.ER is a read/</n>     |
|     | write field.                        |

Reserved, RAZ.

# **CI, bit [8]**

# When the node supports this flag:

Critical Error flag. Describes how the fault generation feature of the node sets the <u>ERR<n>STATUS</u>.CI status flag.

| CI  | Meaning                                   |
|-----|-------------------------------------------|
| 0d0 | When an injected error is recorded, it is |
|     | implementation defined whether the node   |
|     | sets <u>ERR<n>STATUS</n></u> .CI to 1.    |
|     | <u>ERR<n>PFGCTL</n></u> .CI is res0.      |
| 0b1 | When an injected error is recorded,       |
|     | ERR <n>STATUS.CI is set to</n>            |
|     | ERR <n>PFGCTL.CI. ERR<n>PFGCTL.CI</n></n> |
|     | is a read/write field.                    |

This behavior replaces the architecture-defined rules for setting the ERR<n>STATUS.CI bit.

#### Otherwise:

Reserved, RAZ.

# **CE, bits [7:6]**

# When the node supports this type of error:

Corrected Error generation. Describes the types of Corrected error that the fault generation feature of the node can generate.

| CE   | Meaning                                |
|------|----------------------------------------|
| 0b00 | The fault generation feature of the    |
|      | node does not generate Corrected       |
|      | errors. <u>ERR<n>PFGCTL</n></u> .CE is |
|      | res0.                                  |

The fault generation feature of the 0b01 node allows generation of a nonspecific Corrected error, that is, a Corrected error that is recorded by setting ERR<n>STATUS.CE to 0b10. ERR<n>PFGCTL.CE is a read/write field. The values 0b10 and 0b11 in ERR<n>PFGCTL.CE are reserved. The fault generation feature of the 0b11 node allows generation of transient or persistent Corrected errors, that is, Corrected errors that are recorded by setting ERR<n>STATUS.CE to 0b01 or 0b11 respectively. ERR<n>PFGCTL.CE is a read/ write field. The value 0b01 in ERR<n>PFGCTL.CE is reserved.

All other values are reserved.

If <u>ERR<n>FR</u>.FRX is 1 then <u>ERR<n>FR</u>.CE indicates whether the node supports this type of error.

#### Otherwise:

Reserved, RAZ.

# DE, bit [5] When the node supports this type of error:

Deferred Error generation. Describes whether the fault generation feature of the node can generate Deferred errors.

| DE  | Meaning                                  |
|-----|------------------------------------------|
| 0b0 | The fault generation feature of the      |
|     | node does not generate Deferred          |
|     | errors. <u>ERR<n>PFGCTL</n></u> .DE is   |
|     | res0.                                    |
| 0b1 | The fault generation feature of the      |
|     | node allows generation of Deferred       |
|     | errors. <u>ERR<n>PFGCTL</n></u> .DE is a |
|     | read/write field.                        |

If <u>ERR<n>FR</u>.FRX is 1 then <u>ERR<n>FR</u>.DE indicates whether the node supports this type of error.

Reserved, RAZ.

#### **UEO**, bit [4]

# When the node supports this type of error:

Latent or Restartable Error generation. Describes whether the fault generation feature of the node can generate Latent or Restartable errors.

| UEO | Meaning                           |
|-----|-----------------------------------|
| 0d0 | The fault generation feature of   |
|     | the node does not generate Latent |
|     | or Restartable errors.            |
|     | ERR <n>PFGCTL.UEO is res0.</n>    |
| 0b1 | The fault generation feature of   |
|     | the node allows generation of     |
|     | Latent or Restartable errors.     |
|     | ERR <n>PFGCTL.UEO is a read/</n>  |
|     | write field.                      |

If <u>ERR<n>FR</u>.FRX is 1 then <u>ERR<n>FR</u>.UEO indicates whether the node supports this type of error.

#### Otherwise:

Reserved, RAZ.

### UER, bit [3]

#### When the node supports this type of error:

Signaled or Recoverable Error generation. Describes whether the fault generation feature of the node can generate Signaled or Recoverable errors.

| UER | Meaning                          |
|-----|----------------------------------|
| 0b0 | The fault generation feature of  |
|     | the node does not generate       |
|     | Signaled or Recoverable errors.  |
|     | ERR <n>PFGCTL.UER is res0.</n>   |
| 0b1 | The fault generation feature of  |
|     | the node allows generation of    |
|     | Signaled or Recoverable errors.  |
|     | ERR <n>PFGCTL.UER is a read/</n> |
|     | write field.                     |

If <u>ERR<n>FR</u>.FRX is 1 then <u>ERR<n>FR</u>.UER indicates whether the node supports this type of error.

Reserved, RAZ.

# **UEU**, bit [2]

# When the node supports this type of error:

Unrecoverable Error generation. Describes whether the fault generation feature of the node can generate Unrecoverable errors.

| UEU | Meaning                          |
|-----|----------------------------------|
| 0b0 | The fault generation feature of  |
|     | the node does not generate       |
|     | Unrecoverable errors.            |
|     | ERR <n>PFGCTL.UEU is res0.</n>   |
| 0b1 | The fault generation feature of  |
|     | the node allows generation of    |
|     | Unrecoverable errors.            |
|     | ERR <n>PFGCTL.UEU is a read/</n> |
|     | write field.                     |

If <u>ERR<n>FR</u>.FRX is 1 then <u>ERR<n>FR</u>.UEU indicates whether the node supports this type of error.

#### Otherwise:

Reserved, RAZ.

# UC, bit [1]

#### When the node supports this type of error:

Uncontainable Error generation. Describes whether the fault generation feature of the node can generate Uncontainable errors.

| UC  | Meaning                                   |
|-----|-------------------------------------------|
| 0b0 | The fault generation feature of the       |
|     | node does not generate                    |
|     | Uncontainable errors.                     |
|     | <u>ERR<n>PFGCTL</n></u> .UC is res0.      |
| 0b1 | The fault generation feature of the       |
|     | node allows generation of                 |
|     | Uncontainable errors.                     |
|     | <pre>ERR<n>PFGCTL.UC is a read/</n></pre> |
|     | write field.                              |

If <u>ERR<n>FR</u>.FRX is 1 then <u>ERR<n>FR</u>.UC indicates whether the node supports this type of error.

Reserved, RAZ.

# OF, bit [0] When the node supports this flag:

Overflow flag. Describes how the fault generation feature of the node sets the <u>ERR<n>STATUS</u>.OF status flag.

| OF  | Meaning                                   |
|-----|-------------------------------------------|
| 0b0 | When an injected error is recorded,       |
|     | the node sets <u>ERR<n>STATUS</n></u> .OF |
|     | according to the architecture-            |
|     | defined rules for setting the OF          |
|     | field. ERR <n>PFGCTL.OF is res0.</n>      |
| 0b1 | When an injected error is recorded,       |
|     | ERR <n>STATUS.OF is set to</n>            |
|     | ERR <n>PFGCTL.OF. This behavior</n>       |
|     | replaces the architecture-defined         |
|     | rules for setting the OF bit.             |
|     | ERR <n>PFGCTL.OF is a read/</n>           |
|     | write field.                              |

#### Otherwise:

Reserved, RAZ.

# Accessing ERR<n>PFGF

### **ERR**<n>PFGF can be accessed through the memory-mapped interfaces:

| Component | Offset   | Instance        |
|-----------|----------|-----------------|
| RAS       | 0x800 +  | ERR <n>PFGF</n> |
|           | (64 * n) |                 |

Accesses on this interface are **RO**.

| AArch32          | AArch64          | AArch32             | AArch64             | Index by | <u>External</u>  |
|------------------|------------------|---------------------|---------------------|----------|------------------|
| <u>Registers</u> | <u>Registers</u> | <u>Instructions</u> | <u>Instructions</u> | Encoding | <u>Registers</u> |

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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