Index by

**Encoding** 

<u>Base</u> <u>SIMD&FP</u> <u>Instructions</u> <u>Instructions</u> SVE Instructions SME Instructions

# STRH (register)

Store Register Halfword (register) calculates an address from a base register value and an offset register value, and stores a halfword from a 32-bit register to the calculated address. For information about memory accesses, see *Load/Store addressing modes*.

The instruction uses an offset addressing mode, that calculates the address used for the memory access from a base register value and an offset register value. The offset can be optionally shifted and extended.

| 31 30 29 | 9 28 2 | 7 26 | 25 | 24 | 23 | 22 | 21 | 20 19 18 17 16 | 15 14 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
|----------|--------|------|----|----|----|----|----|----------------|----------|----|----|----|---|---|----|---|---|---|---|----|---|---|
| 0 1 1    | 1 1    | 0    | 0  | 0  | 0  | 0  | 1  | Rm             | option   | S  | 1  | 0  |   |   | Rn |   |   |   |   | Rt |   |   |
| size     |        |      |    |    | OI | oc |    |                |          |    |    |    |   |   |    |   |   |   |   |    |   |   |

## **Assembler Symbols**

Solution of the general-purpose register to be the general area dod in the UDAN fold.

transferred, encoded in the "Rt" field.

<Xn|SP> Is the 64-bit name of the general-purpose base register or

stack pointer, encoded in the "Rn" field.

<Wm> When option<0> is set to 0, is the 32-bit name of the

general-purpose index register, encoded in the "Rm" field.

<Xm> When option<0> is set to 1, is the 64-bit name of the

general-purpose index register, encoded in the "Rm" field.

| <extend></extend> |
|-------------------|
| UXTW              |
| LSL               |
| SXTW              |
| SXTX              |
|                   |

<amount>

Is the index shift amount, optional only when <extend> is not LSL. Where it is permitted to be optional, it defaults to #0. It is encoded in "S":

| S | <amount></amount> |
|---|-------------------|
| 0 | #0                |
| 1 | #1                |

### **Shared Decode**

```
integer n = UInt(Rn);
integer t = UInt(Rt);
integer m = UInt(Rm);
```

### **Operation**

#### **Operational information**

If PSTATE.DIT is 1, the timing of this instruction is insensitive to the value of the data being loaded or stored.

 $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