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

Pseu

# PRFB (vector plus immediate)

Gather prefetch bytes (vector plus immediate)

SIMD&FP

**Instructions** 

Gather prefetch of bytes from the active memory addresses generated by a vector base plus immediate index. The index is in the range 0 to 31. Inactive addresses are not prefetched from memory.

**SVE** 

Instructions

The prfop> symbol specifies the prefetch hint as a combination of three
options: access type PLD for load or PST for store; target cache level L1, L2
or L3; temporality (KEEP for temporal or STRM for non-temporal).

This instruction is illegal when executed in Streaming SVE mode, unless FEAT SME FA64 is implemented and enabled.

It has encodings from 2 classes: 32-bit element and 64-bit element

#### 32-bit element

Base

**Instructions** 

```
31302928272625 24 23 22212019181716151413121110 9 8 7 6 5 4 3 2 1 0

1 0 0 0 1 0 0 0 0 imm5 1 1 1 Pg Zn 0 prfop

msz<1>msz<0>
```

```
if !HaveSVE() then UNDEFINED;
constant integer esize = 32;
integer g = UInt(Pg);
integer n = UInt(Zn);
integer level = UInt(prfop<2:1>);
boolean stream = (prfop<0> == '1');
pref_hint = if prfop<3> == '0' then Prefetch READ else Prefetch WRITE;
integer scale = 0;
integer offset = UInt(imm5);
```

#### 64-bit element

```
31302928272625 24 23 22212019181716151413121110 9 8 7 6 5 4 3 2 1 0

1 1 0 0 0 1 0 0 0 0 imm5 1 1 1 Pg Zn 0 prfop

msz<1>msz<0>
```

```
if !HaveSVE() then UNDEFINED;
constant integer esize = 64;
integer g = UInt(Pg);
integer n = UInt(Zn);
integer level = UInt(prfop<2:1>);
boolean stream = (prfop<0> == '1');
pref_hint = if prfop<3> == '0' then Prefetch READ else Prefetch WRITE;
integer scale = 0;
integer offset = UInt(imm5);
```

## **Assembler Symbols**

prfop>

Is the prefetch operation specifier, encoded in "prfop":

| prfop | <pre><pre><pre><pre><pre><pre><pre><pre></pre></pre></pre></pre></pre></pre></pre></pre> |
|-------|------------------------------------------------------------------------------------------|
| 0000  | PLDL1KEEP                                                                                |
| 0001  | PLDL1STRM                                                                                |
| 0010  | PLDL2KEEP                                                                                |
| 0011  | PLDL2STRM                                                                                |
| 0100  | PLDL3KEEP                                                                                |
| 0101  | PLDL3STRM                                                                                |
| x11x  | #uimm4                                                                                   |
| 1000  | PSTL1KEEP                                                                                |
| 1001  | PSTL1STRM                                                                                |
| 1010  | PSTL2KEEP                                                                                |
| 1011  | PSTL2STRM                                                                                |
| 1100  | PSTL3KEEP                                                                                |
| 1101  | PSTL3STRM                                                                                |

<Pg>

Is the name of the governing scalable predicate register P0-

P7, encoded in the "Pg" field.

<Zn>

Is the name of the base scalable vector register, encoded in

the "Zn" field.

<imm>

Is the optional unsigned immediate byte offset, in the range 0 to 31, defaulting to 0, encoded in the "imm5" field.

### **Operation**

```
CheckNonStreamingSVEEnabled();
constant integer VL = CurrentVL;
constant integer PL = VL DIV 8;
constant integer elements = VL DIV esize;
bits(PL) mask = P[g, PL];
bits(VL) base;

if AnyActiveElement(mask, esize) then
    base = Z[n, VL];

for e = 0 to elements-1
    if ActivePredicateElement(mask, e, esize) then
        bits(64) addr = ZeroExtend(Elem[base, e, esize], 64) + (offset < Hint Prefetch(addr, pref_hint, level, stream);</pre>
```

Sh

<u>Pseu</u>

BaseSIMD&FPSVESMEIndex byInstructionsInstructionsInstructionsEncoding

 $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.