| <u>c by</u> | Sh           |
|-------------|--------------|
| ding        | <u>Pseuc</u> |

BaseSIMD&FPSVESMEIndex byInstructionsInstructionsInstructionsInstructionsEncoding

# **SQDECD** (scalar)

Signed saturating decrement scalar by multiple of 64-bit predicate constraint element count

Determines the number of active 64-bit elements implied by the named predicate constraint, multiplies that by an immediate in the range 1 to 16 inclusive, and then uses the result to decrement the scalar destination. The result is saturated to the source general-purpose register's signed integer range. A 32-bit saturated result is then sign-extended to 64 bits.

The named predicate constraint limits the number of active elements in a single predicate to:

- A fixed number (VL1 to VL256)
- The largest power of two (POW2)
- The largest multiple of three or four (MUL3 or MUL4)
- All available, implicitly a multiple of two (ALL).

Unspecified or out of range constraint encodings generate an empty predicate or zero element count rather than Undefined Instruction exception.

It has encodings from 2 classes: 32-bit and 64-bit

### 32-bit

```
3130292827262524 23 22 212019181716151413121110 9 8 7 6 5 4 3 2 1 0

0 0 0 0 0 1 0 0 1 1 1 1 0 imm4 1 1 1 1 1 0 pattern Rdn

size<1>size<0> sf D U
```

```
SQDECD <Xdn>, <Wdn>{, <pattern>{, MUL #<imm>}}
```

```
if ! HaveSVE() && ! HaveSME() then UNDEFINED;
constant integer esize = 64;
integer dn = UInt(Rdn);
bits(5) pat = pattern;
integer imm = UInt(imm4) + 1;
boolean unsigned = FALSE;
constant integer ssize = 32;
```

#### 64-bit

```
3130292827262524 23 22 212019181716151413121110 9 8 7 6 5 4 3 2 1 0

0 0 0 0 0 1 0 0 1 1 1 1 1 1 imm4 1 1 1 1 1 0 pattern Rdn

size<1>size<0> sf D U
```

```
SQDECD <Xdn>{, <pattern>{, MUL #<imm>}}
```

```
if !HaveSVE() && !HaveSME() then UNDEFINED;
constant integer esize = 64;
integer dn = UInt(Rdn);
```

```
bits(5) pat = pattern;
integer imm = UInt(imm4) + 1;
boolean unsigned = FALSE;
constant integer ssize = 64;
```

## **Assembler Symbols**

<Xdn> Is the 64-bit name of the source and destination general-

purpose register, encoded in the "Rdn" field.

<Wdn> Is the 32-bit name of the source and destination general-

purpose register, encoded in the "Rdn" field. <pattern>

Is the optional pattern specifier, defaulting to ALL, encoded in "pattern":

| <pattern></pattern> |
|---------------------|
| POW2                |
| VL1                 |
| VL2                 |
| VL3                 |
| VL4                 |
| VL5                 |
| VL6                 |
| VL7                 |
| VL8                 |
| VL16                |
| VL32                |
| VL64                |
| VL128               |
| VL256               |
| #uimm5              |
| MUL4                |
| MUL3                |
| ALL                 |
|                     |

<imm>

Is the immediate multiplier, in the range 1 to 16, defaulting to 1, encoded in the "imm4" field.

## **Operation**

```
CheckSVEEnabled();
integer count = DecodePredCount(pat, esize);
bits(ssize) operand1 = X[dn, ssize];
bits(ssize) result;

integer element1 = Int(operand1, unsigned);
(result, -) = SatQ(element1 - (count * imm), ssize, unsigned);
X[dn, 64] = Extend(result, 64, unsigned);
```

<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