# LDRSW (register)

Load Register Signed Word (register) calculates an address from a base register value and an offset register value, loads a word from memory, sign-extends it to form a 64-bit value, and writes it to a register. The offset register value can be shifted left by 0 or 2 bits. For information about memory accesses, see *Load/Store addressing modes*.

| 31 30 2 | 29 28 | 27 | 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 |
|---------|-------|----|----|----|----|----|-----|----|----------------|----------|----|----|----|---|---|----|---|---|---|---|----|---|---|
| 1 0     | 1 1   | 1  | 0  | 0  | 0  | 1  | 0   | 1  | Rm             | option   | S  | 1  | 0  |   |   | Rn |   |   |   |   | Rt |   |   |
| size    |       |    |    |    |    | 01 | oc. |    |                | -        |    |    |    |   |   |    |   |   |   |   |    |   |   |

## **Assembler Symbols**

| <xt></xt>         | Is the 64-bit name of the general-purpose register to be transferred, encoded in the "Rt" field.                 |
|-------------------|------------------------------------------------------------------------------------------------------------------|
| <xn sp></xn sp>   | Is the 64-bit name of the general-purpose base register or stack pointer, encoded in the "Rn" field.             |
| <wm></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></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> | Is the index extend/shift specifier, defaulting to I SI                                                          |

Is the index extend/shift specifier, defaulting to LSL, and which must be omitted for the LSL option when <amount> is omitted. encoded in "option":

| option | <extend></extend> |  |  |  |  |  |
|--------|-------------------|--|--|--|--|--|
| 010    | UXTW              |  |  |  |  |  |
| 011    | LSL               |  |  |  |  |  |
| 110    | SXTW              |  |  |  |  |  |
| 111    | 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 | #2                |

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