load16x4_s: Wasm SIMD Lade-/Speicheranweisung
Die load16x4_s SIMD Lade-/Speicheranweisung lädt vier 16-Bit-Integer von einer angegebenen Speicheradresse und erweitert jedes um ein Vorzeichen auf einen 32-Bit-Kanal, ausgeben wird eine v128 Typ i32x4 Wertinterpretation.
Probieren Sie es aus
(module
(import "console" "log" (func $log (param i32)))
(memory $memory 1)
(data (i32.const 0) "\01\02\03\04\05\06\07\08\09\0a\0b\0c\0d\0e\0f\00\01\02\03")
(func $main
i32.const 0
v128.load16x4_s
i32x4.extract_lane 3
call $log
)
(start $main)
)
WebAssembly.instantiateStreaming(fetch("{%wasm-url%}"), { console });
Syntax
;; Common usage v128.load16x4_s ;; With optional immediate operands v128.load16x4_s mem_idx offset=int align=int
v128.load16x4_s-
Die
v128.load16x4_sAnweisung. mem_idxOptional-
Ein Integer, der den Speicherindex darstellt, in Fällen, in denen das Modul mehrere Speicher verwendet. Der Standard ist
0. offset=intOptional-
Ein Integer, der eine konstante Anzahl von Bytes darstellt, die zur Speicheradresse hinzugefügt werden müssen, bevor geladen wird. Der Standard ist
0. align=intOptional-
Ein Integer, der der Wasm-Engine einen Hinweis gibt, welche Ausrichtung für die endgültige Adresse erwartet wird. Der Mindestwert ist
1und der Standard- und Höchstwert ist8. Einalign-Wert muss eine Potenz von2sein.
Typ
[memory_address] -> [output]
memory_address-
Ein Integer, der die Speicheradresse darstellt, von der geladen werden soll.
output-
Die Ausgabe
v128Typi32x4Wertinterpretation.
Binärkodierung
| Anweisung | Binärformat | Beispieltext => binär |
|---|---|---|
v128.load16x4_s |
0xFD 3:u32 mem_idx:u8 offset:u32 align:u32 |
v128.load16x4_s 0 offset=0 align=4 => 0xfd 0x03 0x02 0x00 |
Hinweis:
Während das Wasm-Textformat den wörtlichen align-Wert angibt, stellt das binäre Äquivalent den Exponenten der Formel 2^x dar, die zur Berechnung der Ausrichtung verwendet wird. Zum Beispiel ist align=1 gleichbedeutend mit 0x00 (2^0), während align=8 gleichbedeutend mit 0x03 (2^3) ist.