eq: Wasm text instruction
The eq instruction, short for equal, checks if two numbers are equal.
Try it
(module
(import "env" "log_bool" (func $log_bool (param i32)))
(func $main
;; load `10` and `2` onto the stack
i32.const 10
i32.const 2
i32.eq ;; check if `10` is equal to `2`
call $log_bool ;; log the result
)
(start $main)
)
const url = "{%wasm-url%}";
function log_bool(value) {
console.log(Boolean(value));
// Expected output: false
}
await WebAssembly.instantiateStreaming(fetch(url), {
env: { log_bool },
});
Syntax
value_type.eq
value_type-
The type of value the instruction is being run on. The following types support
eq:i32i64f32f64v128interpretations:i8x16i16x8i32x4i64x2f32x4f64x2
eq-
The
eqinstruction. Must always be included after thevalue_typeand a period (.).
Type
[input1, input2] -> [output]
input1-
The first input value.
input2-
The second input value.
output-
The output value, which will be an integer type.
For a non-SIMD eq, the inputs will be basic numeric values such as 1 or 3.5. If the input values are equal, 1 will be pushed on to the stack as an output, otherwise 0 will be pushed on to the stack.
For a SIMD eq, the inputs will be v128 value interpretations, for example f32x4 0x9 0xa 0xb 0xc. Each lane of the output pushed to the stack is a 1 or 0 indicating the equality of the corresponding lanes in the input values.
Binary encoding
| Instruction | Binary format | Example text => binary |
|---|---|---|
i32.eq |
0x46 |
i32.eq => 0x46 |
i64.eq |
0x51 |
i64.eq => 0x51 |
f32.eq |
0x5b |
f32.eq => 0x5b |
f64.eq |
0x61 |
f64.eq => 0x61 |
i8x16.eq |
0xfd 35:u32 |
i8x16.eq => 0xfd 0x23 |
i16x8.eq |
0xfd 45:u32 |
i16x8.eq => 0xfd 0x2d |
i32x4.eq |
0xfd 55:u32 |
i32x4.eq => 0xfd 0x37 |
i64x2.eq |
0xfd 214:u32 |
i64x2.eq => 0xfd 0xd6 0x01 |
f32x4.eq |
0xfd 65:u32 |
f32x4.eq => 0xfd 0x41 |
f64x2.eq |
0xfd 71:u32 |
f64x2.eq => 0xfd 0x47 |
Examples
>SIMD eq example
In this example, we demonstrate using eq to test whether a lane value from two separate SIMD values are equal.
JavaScript
In our script, we grab a reference to a <p> element that we will output our result to, then define an object for import into Wasm containing a single function that writes a value to the output <p>. We then compile and instantiate our Wasm module using the WebAssembly.instantiateStreaming() method, importing the object in the process.
const outputElem = document.querySelector("p");
const obj = {
output(val) {
outputElem.textContent += val;
},
};
WebAssembly.instantiateStreaming(fetch("{%wasm-url%}"), {
obj,
});
Wasm
In our Wasm module, we first import the JavaScript output() function, making sure to declare that it has an i32 parameter. We then declare two SIMD i16x8 values, then check whether they are equal using i16x8.eq. Finally we extract the value stored in lane 7 of the output value using the extract_lane_s instruction, and output it to the DOM by calling the imported output() function.
(module
;; Import output function
(import "obj" "output" (func $output (param i32)))
(func $main
;; load two SIMD values onto the stack
v128.const i16x8 20 12 15 100 9 8 -7 8
v128.const i16x8 20 12 15 100 9 8 -7 4
i16x8.eq ;; check whether the values are equal
i16x8.extract_lane_s 7 ;; Extract a value from the result
call $output
)
(start $main)
)
Result
The output is as follows:
The result is 0 because the values stored in lane 7 of the two input values are not equal.