| <u>SME</u>   | Index by |
|--------------|----------|
| Instructions | Encoding |

Sh

Pseu

# SMAXP

Base

Instructions

Signed Maximum Pairwise. This instruction creates a vector by concatenating the vector elements of the first source SIMD&FP register after the vector elements of the second source SIMD&FP register, reads each pair of adjacent vector elements in the two source SIMD&FP registers, writes the largest of each pair of signed integer values into a vector, and writes the vector to the destination SIMD&FP register.

**SVE** 

**Instructions** 

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 25 24 23 22 21                       | 20 19 18 17 16 15 14 1 | 3 12 11 10 | 9 8 7 6 5 | 4 3 2 1 0 |
|----------------|-----------------------------------------|------------------------|------------|-----------|-----------|
| 0 Q 0 0 1      | 1 1 0 size 1                            | Rm 1 0 1               | 1 0 0 1    | Rn        | Rd        |
| U              | , , , , , , , , , , , , , , , , , , , , |                        | 01         |           |           |

```
SMAXP <Vd>.<T>, <Vn>.<T>, <Vm>.<T>
```

SIMD&FP

Instructions

```
integer d = UInt(Rd);
integer n = UInt(Rn);
integer m = UInt(Rm);
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');
boolean minimum = (o1 == '1');</pre>
```

## **Assembler Symbols**

<Vd>

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

<T>

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 | 2S       |
|   | 10   | 1 | 4S       |
|   | 11   | Х | RESERVED |
|   |      |   |          |

<Vn>

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

<Vm>

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

### **Operation**

```
CheckFPAdvSIMDEnabled64();
bits(datasize) operand1 = V[n, datasize];
bits(datasize) operand2 = V[m, datasize];
bits(datasize) result;
bits(2*datasize) concat = operand2:operand1;
integer element1;
integer element2;
integer maxmin;

for e = 0 to elements-1
    element1 = Int(Elem[concat, 2*e, esize], unsigned);
    element2 = Int(Elem[concat, (2*e)+1, esize], unsigned);
    maxmin = if minimum then Min(element1, element2) else Max(element1, Elem[result, e, esize] = maxmin
V[d, datasize] = 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.

<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