| <u>ex by</u> | <u>Sh</u>    |
|--------------|--------------|
| oding        | <u>Pseuc</u> |

BaseSIMD&FPSVESMEIndex byInstructionsInstructionsInstructionsInstructionsEncoding

### **MSUB**

Multiply-Subtract multiplies two register values, subtracts the product from a third register value, and writes the result to the destination register. This instruction is used by the alias MNEG.

| 31 30 29 28 2 | 27 26 | 25 24 | 23 | 22 2 | L 20 19 18 17 16 | 15 | 14 13 12 11 10 | 9 | 8 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
|---------------|-------|-------|----|------|------------------|----|----------------|---|-----|---|---|---|---|----|---|---|
| sf 0 0 1      | 1 0   | 1 1   | 0  | 0 0  | Rm               | 1  | Ra             |   | Rr  | 1 |   |   |   | Rd |   |   |
| 00            |       |       |    |      |                  |    |                |   |     |   |   |   |   |    |   |   |

```
32-bit (sf == 0)
```

```
MSUB <Wd>, <Wn>, <Wm>, <Wa>

64-bit (sf == 1)

MSUB <Xd>, <Xn>, <Xm>, <Xa>

integer d = UInt(Rd);
integer n = UInt(Rn);
integer m = UInt(Rm);
integer a = UInt(Rm);
constant integer destsize = 32 << UInt(sf);</pre>
```

# **Assembler Symbols**

| <wd></wd> | Is the 32-bit name of the general-purpose destination register, encoded in the "Rd" field.                           |
|-----------|----------------------------------------------------------------------------------------------------------------------|
| <wn></wn> | Is the 32-bit name of the first general-purpose source register holding the multiplicand, encoded in the "Rn" field. |
| <wm></wm> | Is the 32-bit name of the second general-purpose source register holding the multiplier, encoded in the "Rm" field.  |
| <wa></wa> | Is the 32-bit name of the third general-purpose source register holding the minuend, encoded in the "Ra" field.      |
| <xd></xd> | Is the 64-bit name of the general-purpose destination register, encoded in the "Rd" field.                           |
| <xn></xn> | Is the 64-bit name of the first general-purpose source register holding the multiplicand, encoded in the "Rn" field. |
| <xm></xm> | Is the 64-bit name of the second general-purpose source register holding the multiplier, encoded in the "Rm" field.  |
| <xa></xa> | Is the 64-bit name of the third general-purpose source register holding the minuend, encoded in the "Ra" field.      |
|           |                                                                                                                      |

#### **Alias Conditions**

| Alias | Is preferred when |  |  |  |
|-------|-------------------|--|--|--|
| MNEG  | Ra == '11111'     |  |  |  |

### **Operation**

```
bits(destsize) operand1 = X[n, destsize];
bits(destsize) operand2 = X[m, destsize];
bits(destsize) operand3 = X[a, destsize];
integer result;

result = UInt(operand3) - (UInt(operand1) * UInt(operand2));
X[d, destsize] = result<destsize-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>         | SIMD&FP             | <u>SVE</u>          | <u>SME</u>          | <u>Index by</u> |
|---------------------|---------------------|---------------------|---------------------|-----------------|
| <u>Instructions</u> | <u>Instructions</u> | <u>Instructions</u> | <u>Instructions</u> | Encoding        |

 $Internal\ version\ only:\ is a\ 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