## **SADDLV**

Signed Add Long across Vector. This instruction adds every vector element in the source SIMD&FP register together, and writes the scalar result to the destination SIMD&FP register. The destination scalar is twice as long as the source vector elements. All the values in this instruction are signed integer values.

Depending on the settings in the *CPACR\_EL1*, *CPTR\_EL2*, and *CPTR\_EL3* registers, and the current Security state and Exception level, an attempt to execute the instruction might be trapped.

| 31 30 29 28 27 26 2 | 25 24 23 22 2 | 21 20 19 18 17 | 16 15 14 13 12 11 10 | 9 8 7 6 5 | 4 3 2 1 0 |
|---------------------|---------------|----------------|----------------------|-----------|-----------|
| 0 Q 0 0 1 1         | 1 0 size 1    | 1 1 0 0 0      | 0 0 0 1 1 1 0        | Rn        | Rd        |
| U                   |               |                |                      |           |           |

```
SADDLV <V><d>, <Vn>.<T>
```

```
integer d = UInt(Rd);
integer n = UInt(Rn);

if size:Q == '100' then UNDEFINED;
if size == '11' then UNDEFINED;
constant integer esize = 8 << UInt(size);
constant integer datasize = 64 << UInt(Q);
integer elements = datasize DIV esize;

boolean unsigned = (U == '1');</pre>
```

## **Assembler Symbols**

<V>

Is the destination width specifier, encoded in "size":

| size | <v></v>  |
|------|----------|
| 0.0  | Н        |
| 01   | S        |
| 10   | D        |
| 11   | RESERVED |

<d>

Is the number of the SIMD&FP destination register, encoded in the "Rd" field.

<Vn>

Is the name of the SIMD&FP source register, encoded in the "Rn" field.

Is an arrangement specifier, encoded in "size:Q":

| size | Q | <t></t>  |
|------|---|----------|
| 00   | 0 | 8B       |
| 00   | 1 | 16B      |
| 01   | 0 | 4H       |
| 01   | 1 | 8H       |
| 10   | 0 | RESERVED |
| 10   | 1 | 4S       |
| 11   | Х | RESERVED |
|      |   |          |

## **Operation**

```
CheckFPAdvSIMDEnabled64();
bits(datasize) operand = V[n, datasize];
integer sum;

sum = Int(Elem[operand, 0, esize], unsigned);
for e = 1 to elements-1
    sum = sum + Int(Elem[operand, e, esize], unsigned);

V[d, 2*esize] = sum<2*esize-1:0>;
```

## **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.

<u>Base</u> <u>SIMD&FP</u> <u>SVE</u> <u>SME</u> <u>Index by</u> Instructions Instructions Instructions Encoding

Internal version only: isa v33.64, AdvSIMD v29.12, pseudocode no diffs 2023 09 RC2, sve v2023-06 rel ; Build timestamp: 2023-09-18T17:56

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

Sh Pseu