## C6.2.3 ADD (extended register)

Add (extended register) adds a register value and a sign or zero-extended register value, followed by an optional left shift amount, and writes the result to the destination register. The argument that is extended from the <Rm> register can be a byte, halfword, word, or doubleword.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  16 | 15 13  | 12  10 | 9   8 | 54 | 0  |
|----|----|----|----|----|----|----|----|----|----|----|--------|--------|--------|-------|----|----|
| sf | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 0  | 1  | Rm     | option | imm3   | Rn    | F  | ٦d |
|    | ор | S  |    |    |    |    |    |    |    |    |        |        |        |       |    |    |

#### 32-bit variant

Applies when sf == 0.

ADD <Wd|WSP>, <Wn|WSP>, <Wm>{, <extend> {#<amount>}}

#### 64-bit variant

Applies when sf == 1.

ADD <Xd|SP>, <Xn|SP>, <R><m>{, <extend> {#<amount>}}

### Decode for all variants of this encoding

```
integer d = UInt(Rd);
integer n = UInt(Rn);
integer m = UInt(Rm);
integer datasize = if sf == '1' then 64 else 32;
ExtendType extend_type = DecodeRegExtend(option);
integer shift = UInt(imm3);
if shift > 4 then UNDEFINED;
```

### **Assembler symbols**

| <wd wsp></wd wsp> | Is the 32-bit name of the destination general-purpose register or stack pointer, encoded in the "Rd' field.  |                                                                                                       |  |  |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| <wn wsp></wn wsp> | Is the 32-bit name of the first source general-purpose register or stack pointer, encoded in the "Rn" field. |                                                                                                       |  |  |  |  |  |
| <wm></wm>         | Is the 32-bit name of the second general-purpose source register, encoded in the "Rm" field.                 |                                                                                                       |  |  |  |  |  |
| <xd sp></xd sp>   | Is the 64-bit name of the destination general-purpose register or stack pointer, encoded in the "Rd" field.  |                                                                                                       |  |  |  |  |  |
| <xn sp></xn sp>   | Is the 64-bit name of the first source general-purpose register or stack pointer, encoded in the "Rn" field. |                                                                                                       |  |  |  |  |  |
| <r></r>           | Is a wi                                                                                                      | dth specifier, encoded in the "option" field. It can have the following values:                       |  |  |  |  |  |
|                   | W                                                                                                            | when $option = 00x$                                                                                   |  |  |  |  |  |
|                   | W                                                                                                            | when $option = 010$                                                                                   |  |  |  |  |  |
|                   | х                                                                                                            | when $option = x11$                                                                                   |  |  |  |  |  |
|                   | W                                                                                                            | when $option = 10x$                                                                                   |  |  |  |  |  |
|                   | W                                                                                                            | when $option = 110$                                                                                   |  |  |  |  |  |
| <m></m>           | Is the 1<br>the "R                                                                                           | number [0-30] of the second general-purpose source register or the name ZR (31), encoded in m" field. |  |  |  |  |  |

<extend> For the 32-bit variant: is the extension to be applied to the second source operand, encoded in the "option" field. It can have the following values:

| UXTB     | when option = $000$ |
|----------|---------------------|
| UXTH     | when option = 001   |
| LSL UXTW | when option = $010$ |
| UXTX     | when option = $011$ |
| SXTB     | when option = 100   |
| SXTH     | when option = 101   |
| SXTW     | when option = 110   |
| SXTX     | when option = 111   |

If "Rd" or "Rn" is '11111' (WSP) and "option" is '010' then LSL is preferred, but may be omitted when "imm3" is '000'. In all other cases <extend> is required and must be UXTW when "option" is '010'.

For the 64-bit variant: is the extension to be applied to the second source operand, encoded in the "option" field. It can have the following values:

| UXTB     | when option = 000   |
|----------|---------------------|
| UXTH     | when option = $001$ |
| UXTW     | when option = $010$ |
| LSL UXTX | when option = $011$ |
| SXTB     | when option = $100$ |
| SXTH     | when option = $101$ |
| SXTW     | when option = $110$ |
| SXTX     | when option = 111   |

If "Rd" or "Rn" is '11111' (SP) and "option" is '011' then LSL is preferred, but may be omitted when "imm3" is '000'. In all other cases <extend> is required and must be UXTX when "option" is '011'.

<amount> Is the left shift amount to be applied after extension in the range 0 to 4, defaulting to 0, encoded in the "imm3" field. It must be absent when <extend> is absent, is required when <extend> is LSL, and is optional when <extend> is present but not LSL.

# Operation

```
bits(datasize) result;
bits(datasize) operand1 = if n == 31 then SP[] else X[n];
bits(datasize) operand2 = ExtendReg(m, extend_type, shift);
(result, -) = AddWithCarry(operand1, operand2, '0');
if d == 31 then
    SP[] = result;
else
    X[d] = result;
```

## **Operational information**

If PSTATE.DIT is 1:

•

- The execution time of this instruction is independent of:
  - The values of the data supplied in any of its registers.
  - The values of the NZCV flags.
  - The response of this instruction to asynchronous exceptions does not vary based on:
    - The values of the data supplied in any of its registers.

— The values of the NZCV flags.