| <u>Base</u>         | SIMD&FP             | <u>SVE</u>          | <u>SME</u>          | Index by        |
|---------------------|---------------------|---------------------|---------------------|-----------------|
| <u>Instructions</u> | <u>Instructions</u> | <u>Instructions</u> | <u>Instructions</u> | <b>Encoding</b> |

## **ADR**

Form PC-relative address adds an immediate value to the PC value to form a PC-relative address, and writes the result to the destination register.

| 31 30 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 |
|-------------------------|-----------------------------------------------------|---|-----|----|---|
| 0 immlp1 0 0 0 0        | immhi                                               |   |     | Rd |   |
| op                      |                                                     |   |     |    |   |

```
ADR <Xd>, <label>
integer d = UInt(Rd);
bits(64) imm;
imm = SignExtend(immhi:immlo, 64);
```

## **Assembler Symbols**

<Xd> Is the 64-bit name of the general-purpose destination

register, encoded in the "Rd" field.

offset from the address of this instruction, in the range

+/-1MB, is encoded in "immhi:immlo".

## **Operation**

```
bits(64) base = PC[];

X[d, 64] = base + imm;
```

<u>Base SIMD&FP SVE SME Index by</u> <u>Instructions Instructions Instructions Encoding</u>

 $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

Pseu