AArch64 Instructions Index by Encoding

External Registers

## GICD\_CPENDSGIR<n>, SGI Clear-Pending Registers, n = 0 - 3

The GICD CPENDSGIR<n> characteristics are:

## **Purpose**

Removes the pending state from an SGI.

A write to this register changes the state of a pending SGI to inactive, and the state of an active and pending SGI to active.

## **Configuration**

Four SGI clear-pending registers are implemented. Each register contains eight clear-pending bits for each of four SGIs, for a total of 16 possible SGIs.

In multiprocessor implementations, each PE has a copy of these registers.

#### **Attributes**

GICD CPENDSGIR<n> is a 32-bit register.

## Field descriptions

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 SGI\_clear\_pending\_b \$63\_clear\_pending\_b \$63\_clear\_pending\_b

SGI\_clear\_pending\_bits<x>, bits [8x+7:8x], for x = 3 to 0

Removes the pending state from SGI number 4n + x for the PE corresponding to the bit number written to.

Reads and writes have the following behavior:

| SGI_clear_pending_bits <x> Meaning</x> |  |
|----------------------------------------|--|
|----------------------------------------|--|

| 0x00 | If read, indicates that the SGI from the corresponding PE is not pending and is not active and pending. If written, has                                                                 |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x01 | no effect.  If read, indicates that the SGI from the corresponding PE is pending or is active and pending. If written, removes the pending state from the SGI for the corresponding PE. |

The reset behavior of this field is:

• On a GIC reset, this field resets to 0.

For SGI ID m, generated by processing element C writing to the corresponding <u>GICD\_SGIR</u> field, where DIV and MOD are the integer division and modulo operations:

- The corresponding GICD\_CPENDSGIR<n> number is given by n = m DIV 4.
- The offset of the required register is (0xF10 + (4n)).
- The offset of the required field within the register GICD CPENDSGIR<n> is given by m MOD 4.
- The required bit in the 8-bit SGI clear-pending field m is bit C.

### Accessing GICD\_CPENDSGIR<n>

These registers are used only when affinity routing is not enabled. When affinity routing is enabled, this register is res0. An implementation is permitted to make the register RAZ/WI in this case.

A register bit that corresponds to an unimplemented SGI is RAZ/WI.

These registers are byte-accessible.

If the GIC implementation supports two Security states:

- A register bit that corresponds to a Group 0 interrupt is RAZ/WI to Non-secure accesses.
- Register bits corresponding to unimplemented PEs are RAZ/WI.

# GICD\_CPENDSGIR<n> can be accessed through the memory-mapped interfaces:

| Component          | Frame     | Offset                 | Instance               |
|--------------------|-----------|------------------------|------------------------|
| GIC<br>Distributor | Dist_base | 0x0F10<br>+ (4 *<br>n) | GICD_CPENDSGIR <n></n> |

Accesses on this interface are RW.

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

28/03/2023 16:01; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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