Files
wasmtime/cranelift/filetests/filetests/runtests/fcmp-ueq.clif
Afonso Bordado f30a7eb0c9 cranelift: Implement PartialEq on Ieee{32,64} (#4849)
* cranelift: Add `fcmp` tests

Some of these are disabled on aarch64 due to not being implemented yet.

* cranelift: Implement float PartialEq for Ieee{32,64} (fixes #4828)

Previously `PartialEq` was auto derived. This means that it was implemented in terms of PartialEq in a u32.

This is not correct for floats because `NaN != NaN`.

PartialOrd was manually implemented in 6d50099816, but it seems like it was an oversight to leave PartialEq out until now.

The test suite depends on the previous behaviour so we adjust it to keep comparing bits instead of floats.

* cranelift: Disable `fcmp ord` tests on aarch64

* cranelift: Disable `fcmp ueq` tests on aarch64
2022-09-02 10:42:42 -07:00

319 lines
13 KiB
Plaintext

test interpret
test run
target x86_64
target s390x
function %fcmp_ueq_f32(f32, f32) -> b1 {
block0(v0: f32, v1: f32):
v2 = fcmp ueq v0, v1
return v2
}
; run: %fcmp_ueq_f32(0x0.5, 0x0.5) == true
; run: %fcmp_ueq_f32(0x1.0, 0x1.0) == true
; run: %fcmp_ueq_f32(-0x1.0, 0x1.0) == false
; run: %fcmp_ueq_f32(0x1.0, -0x1.0) == false
; run: %fcmp_ueq_f32(0x0.5, 0x1.0) == false
; run: %fcmp_ueq_f32(0x1.5, 0x2.9) == false
; run: %fcmp_ueq_f32(0x1.1p10, 0x1.4p1) == false
; run: %fcmp_ueq_f32(0x1.4cccccp0, 0x1.8p0) == false
; run: %fcmp_ueq_f32(0x1.b33334p0, 0x1.99999ap-2) == false
; run: %fcmp_ueq_f32(0x1.333334p-1, 0x1.666666p1) == false
; run: %fcmp_ueq_f32(-0x0.5, -0x1.0) == false
; run: %fcmp_ueq_f32(-0x1.5, -0x2.9) == false
; run: %fcmp_ueq_f32(-0x1.1p10, -0x1.333334p-1) == false
; run: %fcmp_ueq_f32(-0x1.99999ap-2, -0x1.4cccccp0) == false
; run: %fcmp_ueq_f32(-0x1.8p0, -0x1.b33334p0) == false
; run: %fcmp_ueq_f32(-0x1.4p1, -0x1.666666p1) == false
; run: %fcmp_ueq_f32(0x0.5, -0x1.0) == false
; run: %fcmp_ueq_f32(0x1.b33334p0, -0x1.b33334p0) == false
; Zeroes
; run: %fcmp_ueq_f32(0x0.0, 0x0.0) == true
; run: %fcmp_ueq_f32(-0x0.0, -0x0.0) == true
; run: %fcmp_ueq_f32(0x0.0, -0x0.0) == true
; run: %fcmp_ueq_f32(-0x0.0, 0x0.0) == true
; Infinities
; run: %fcmp_ueq_f32(Inf, Inf) == true
; run: %fcmp_ueq_f32(-Inf, -Inf) == true
; run: %fcmp_ueq_f32(Inf, -Inf) == false
; run: %fcmp_ueq_f32(-Inf, Inf) == false
; Inf/Zero
; run: %fcmp_ueq_f32(0x0.0, Inf) == false
; run: %fcmp_ueq_f32(-0x0.0, Inf) == false
; run: %fcmp_ueq_f32(0x0.0, -Inf) == false
; run: %fcmp_ueq_f32(-0x0.0, -Inf) == false
; run: %fcmp_ueq_f32(Inf, 0x0.0) == false
; run: %fcmp_ueq_f32(Inf, -0x0.0) == false
; run: %fcmp_ueq_f32(-Inf, 0x0.0) == false
; run: %fcmp_ueq_f32(-Inf, -0x0.0) == false
; Epsilon / Max / Min Positive
; run: %fcmp_ueq_f32(0x1.0p-23, 0x1.0p-23) == true
; run: %fcmp_ueq_f32(0x1.fffffep127, 0x1.fffffep127) == true
; run: %fcmp_ueq_f32(0x1.0p-126, 0x1.0p-126) == true
; run: %fcmp_ueq_f32(0x1.0p-23, 0x1.fffffep127) == false
; run: %fcmp_ueq_f32(0x1.0p-23, 0x1.0p-126) == false
; run: %fcmp_ueq_f32(0x1.0p-126, 0x1.fffffep127) == false
; Subnormals
; run: %fcmp_ueq_f32(0x0.800002p-126, -0x0.800002p-126) == false
; run: %fcmp_ueq_f32(-0x0.800002p-126, 0x0.800002p-126) == false
; run: %fcmp_ueq_f32(0x0.800002p-126, 0x0.0) == false
; run: %fcmp_ueq_f32(-0x0.800002p-126, 0x0.0) == false
; run: %fcmp_ueq_f32(0x0.800002p-126, -0x0.0) == false
; run: %fcmp_ueq_f32(-0x0.800002p-126, -0x0.0) == false
; run: %fcmp_ueq_f32(0x0.0, 0x0.800002p-126) == false
; run: %fcmp_ueq_f32(0x0.0, -0x0.800002p-126) == false
; run: %fcmp_ueq_f32(-0x0.0, 0x0.800002p-126) == false
; run: %fcmp_ueq_f32(-0x0.0, -0x0.800002p-126) == false
; NaN's
; run: %fcmp_ueq_f32(+NaN, +NaN) == true
; run: %fcmp_ueq_f32(-NaN, -NaN) == true
; run: %fcmp_ueq_f32(+NaN, -NaN) == true
; run: %fcmp_ueq_f32(-NaN, +NaN) == true
; run: %fcmp_ueq_f32(+NaN, -0x1.0) == true
; run: %fcmp_ueq_f32(-NaN, -0x1.0) == true
; run: %fcmp_ueq_f32(+NaN, 0x1.0) == true
; run: %fcmp_ueq_f32(-NaN, 0x1.0) == true
; run: %fcmp_ueq_f32(+NaN, -0x0.0) == true
; run: %fcmp_ueq_f32(-NaN, -0x0.0) == true
; run: %fcmp_ueq_f32(+NaN, 0x0.0) == true
; run: %fcmp_ueq_f32(-NaN, 0x0.0) == true
; run: %fcmp_ueq_f32(+NaN, -Inf) == true
; run: %fcmp_ueq_f32(-NaN, -Inf) == true
; run: %fcmp_ueq_f32(+NaN, Inf) == true
; run: %fcmp_ueq_f32(-NaN, Inf) == true
; run: %fcmp_ueq_f32(-0x0.0, +NaN) == true
; run: %fcmp_ueq_f32(-0x0.0, -NaN) == true
; run: %fcmp_ueq_f32(0x0.0, +NaN) == true
; run: %fcmp_ueq_f32(0x0.0, -NaN) == true
; run: %fcmp_ueq_f32(-Inf, +NaN) == true
; run: %fcmp_ueq_f32(-Inf, -NaN) == true
; run: %fcmp_ueq_f32(Inf, +NaN) == true
; run: %fcmp_ueq_f32(Inf, -NaN) == true
; run: %fcmp_ueq_f32(+NaN:0x1, +NaN:0x1) == true
; run: %fcmp_ueq_f32(-NaN:0x1, -NaN:0x1) == true
; run: %fcmp_ueq_f32(+NaN:0x1, -NaN:0x1) == true
; run: %fcmp_ueq_f32(-NaN:0x1, +NaN:0x1) == true
; run: %fcmp_ueq_f32(+NaN:0x1, +NaN) == true
; run: %fcmp_ueq_f32(+NaN:0x1, -NaN) == true
; run: %fcmp_ueq_f32(-NaN:0x1, -NaN) == true
; run: %fcmp_ueq_f32(-NaN:0x1, +NaN) == true
; run: %fcmp_ueq_f32(+NaN:0x80001, +NaN:0x80001) == true
; run: %fcmp_ueq_f32(-NaN:0x80001, -NaN:0x80001) == true
; run: %fcmp_ueq_f32(+NaN:0x80001, -NaN:0x80001) == true
; run: %fcmp_ueq_f32(-NaN:0x80001, +NaN:0x80001) == true
; run: %fcmp_ueq_f32(+NaN:0x80001, +NaN) == true
; run: %fcmp_ueq_f32(+NaN:0x80001, -NaN) == true
; run: %fcmp_ueq_f32(-NaN:0x80001, -NaN) == true
; run: %fcmp_ueq_f32(-NaN:0x80001, +NaN) == true
; sNaN's
; run: %fcmp_ueq_f32(+sNaN:0x1, +sNaN:0x1) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(+sNaN:0x1, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, +sNaN:0x1) == true
; run: %fcmp_ueq_f32(+sNaN:0x1, -0x1.0) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, -0x1.0) == true
; run: %fcmp_ueq_f32(+sNaN:0x1, 0x1.0) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, 0x1.0) == true
; run: %fcmp_ueq_f32(+sNaN:0x1, -0x0.0) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, -0x0.0) == true
; run: %fcmp_ueq_f32(+sNaN:0x1, 0x0.0) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, 0x0.0) == true
; run: %fcmp_ueq_f32(+sNaN:0x1, -Inf) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, -Inf) == true
; run: %fcmp_ueq_f32(+sNaN:0x1, Inf) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, Inf) == true
; run: %fcmp_ueq_f32(-0x0.0, +sNaN:0x1) == true
; run: %fcmp_ueq_f32(-0x0.0, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(0x0.0, +sNaN:0x1) == true
; run: %fcmp_ueq_f32(0x0.0, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(-Inf, +sNaN:0x1) == true
; run: %fcmp_ueq_f32(-Inf, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(Inf, +sNaN:0x1) == true
; run: %fcmp_ueq_f32(Inf, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(+sNaN:0x1, +NaN:0x1) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, -NaN:0x1) == true
; run: %fcmp_ueq_f32(+sNaN:0x1, -NaN:0x1) == true
; run: %fcmp_ueq_f32(-sNaN:0x1, +NaN:0x1) == true
; run: %fcmp_ueq_f32(+NaN:0x1, +sNaN:0x1) == true
; run: %fcmp_ueq_f32(-NaN:0x1, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(-NaN:0x1, +sNaN:0x1) == true
; run: %fcmp_ueq_f32(+NaN:0x1, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(+sNaN:0x80001, +sNaN:0x80001) == true
; run: %fcmp_ueq_f32(-sNaN:0x80001, -sNaN:0x80001) == true
; run: %fcmp_ueq_f32(+sNaN:0x80001, -sNaN:0x80001) == true
; run: %fcmp_ueq_f32(-sNaN:0x80001, +sNaN:0x80001) == true
; run: %fcmp_ueq_f32(+sNaN:0x80001, +sNaN:0x1) == true
; run: %fcmp_ueq_f32(+sNaN:0x80001, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(-sNaN:0x80001, -sNaN:0x1) == true
; run: %fcmp_ueq_f32(-sNaN:0x80001, +sNaN:0x1) == true
function %fcmp_ueq_f64(f64, f64) -> b1 {
block0(v0: f64, v1: f64):
v2 = fcmp ueq v0, v1
return v2
}
; run: %fcmp_ueq_f64(0x0.5, 0x0.5) == true
; run: %fcmp_ueq_f64(0x1.0, 0x1.0) == true
; run: %fcmp_ueq_f64(-0x1.0, 0x1.0) == false
; run: %fcmp_ueq_f64(0x1.0, -0x1.0) == false
; run: %fcmp_ueq_f64(0x0.5, 0x1.0) == false
; run: %fcmp_ueq_f64(0x1.5, 0x2.9) == false
; run: %fcmp_ueq_f64(0x1.1p10, 0x1.4p1) == false
; run: %fcmp_ueq_f64(0x1.4cccccccccccdp0, 0x1.8p0) == false
; run: %fcmp_ueq_f64(0x1.b333333333333p0, 0x1.999999999999ap-2) == false
; run: %fcmp_ueq_f64(0x1.3333333333333p-1, 0x1.6666666666666p1) == false
; run: %fcmp_ueq_f64(-0x0.5, -0x1.0) == false
; run: %fcmp_ueq_f64(-0x1.5, -0x2.9) == false
; run: %fcmp_ueq_f64(-0x1.1p10, -0x1.3333333333333p-1) == false
; run: %fcmp_ueq_f64(-0x1.999999999999ap-2, -0x1.4cccccccccccdp0) == false
; run: %fcmp_ueq_f64(-0x1.8p0, -0x1.b333333333333p0) == false
; run: %fcmp_ueq_f64(-0x1.4p1, -0x1.6666666666666p1) == false
; run: %fcmp_ueq_f64(0x0.5, -0x1.0) == false
; run: %fcmp_ueq_f64(0x1.b333333333333p0, -0x1.b333333333333p0) == false
; Zeroes
; run: %fcmp_ueq_f64(0x0.0, 0x0.0) == true
; run: %fcmp_ueq_f64(-0x0.0, -0x0.0) == true
; run: %fcmp_ueq_f64(0x0.0, -0x0.0) == true
; run: %fcmp_ueq_f64(-0x0.0, 0x0.0) == true
; Infinities
; run: %fcmp_ueq_f64(Inf, Inf) == true
; run: %fcmp_ueq_f64(-Inf, -Inf) == true
; run: %fcmp_ueq_f64(Inf, -Inf) == false
; run: %fcmp_ueq_f64(-Inf, Inf) == false
; Inf/Zero
; run: %fcmp_ueq_f64(0x0.0, Inf) == false
; run: %fcmp_ueq_f64(-0x0.0, Inf) == false
; run: %fcmp_ueq_f64(0x0.0, -Inf) == false
; run: %fcmp_ueq_f64(-0x0.0, -Inf) == false
; run: %fcmp_ueq_f64(Inf, 0x0.0) == false
; run: %fcmp_ueq_f64(Inf, -0x0.0) == false
; run: %fcmp_ueq_f64(-Inf, 0x0.0) == false
; run: %fcmp_ueq_f64(-Inf, -0x0.0) == false
; Epsilon / Max / Min Positive
; run: %fcmp_ueq_f64(0x1.0p-52, 0x1.0p-52) == true
; run: %fcmp_ueq_f64(0x1.fffffffffffffp1023, 0x1.fffffffffffffp1023) == true
; run: %fcmp_ueq_f64(0x1.0p-1022, 0x1.0p-1022) == true
; run: %fcmp_ueq_f64(0x1.0p-52, 0x1.fffffffffffffp1023) == false
; run: %fcmp_ueq_f64(0x1.0p-52, 0x1.0p-1022) == false
; run: %fcmp_ueq_f64(0x1.0p-1022, 0x1.fffffffffffffp1023) == false
; Subnormals
; run: %fcmp_ueq_f64(0x0.8p-1022, -0x0.8p-1022) == false
; run: %fcmp_ueq_f64(-0x0.8p-1022, 0x0.8p-1022) == false
; run: %fcmp_ueq_f64(0x0.8p-1022, 0x0.0) == false
; run: %fcmp_ueq_f64(-0x0.8p-1022, 0x0.0) == false
; run: %fcmp_ueq_f64(0x0.8p-1022, -0x0.0) == false
; run: %fcmp_ueq_f64(-0x0.8p-1022, -0x0.0) == false
; run: %fcmp_ueq_f64(0x0.0, 0x0.8p-1022) == false
; run: %fcmp_ueq_f64(0x0.0, -0x0.8p-1022) == false
; run: %fcmp_ueq_f64(-0x0.0, 0x0.8p-1022) == false
; run: %fcmp_ueq_f64(-0x0.0, -0x0.8p-1022) == false
; NaN's
; run: %fcmp_ueq_f64(+NaN, +NaN) == true
; run: %fcmp_ueq_f64(-NaN, -NaN) == true
; run: %fcmp_ueq_f64(+NaN, -NaN) == true
; run: %fcmp_ueq_f64(-NaN, +NaN) == true
; run: %fcmp_ueq_f64(+NaN, -0x1.0) == true
; run: %fcmp_ueq_f64(-NaN, -0x1.0) == true
; run: %fcmp_ueq_f64(+NaN, 0x1.0) == true
; run: %fcmp_ueq_f64(-NaN, 0x1.0) == true
; run: %fcmp_ueq_f64(+NaN, -0x0.0) == true
; run: %fcmp_ueq_f64(-NaN, -0x0.0) == true
; run: %fcmp_ueq_f64(+NaN, 0x0.0) == true
; run: %fcmp_ueq_f64(-NaN, 0x0.0) == true
; run: %fcmp_ueq_f64(+NaN, -Inf) == true
; run: %fcmp_ueq_f64(-NaN, -Inf) == true
; run: %fcmp_ueq_f64(+NaN, Inf) == true
; run: %fcmp_ueq_f64(-NaN, Inf) == true
; run: %fcmp_ueq_f64(-0x0.0, +NaN) == true
; run: %fcmp_ueq_f64(-0x0.0, -NaN) == true
; run: %fcmp_ueq_f64(0x0.0, +NaN) == true
; run: %fcmp_ueq_f64(0x0.0, -NaN) == true
; run: %fcmp_ueq_f64(-Inf, +NaN) == true
; run: %fcmp_ueq_f64(-Inf, -NaN) == true
; run: %fcmp_ueq_f64(Inf, +NaN) == true
; run: %fcmp_ueq_f64(Inf, -NaN) == true
; run: %fcmp_ueq_f64(+NaN:0x1, +NaN:0x1) == true
; run: %fcmp_ueq_f64(-NaN:0x1, -NaN:0x1) == true
; run: %fcmp_ueq_f64(+NaN:0x1, -NaN:0x1) == true
; run: %fcmp_ueq_f64(-NaN:0x1, +NaN:0x1) == true
; run: %fcmp_ueq_f64(+NaN:0x1, +NaN) == true
; run: %fcmp_ueq_f64(+NaN:0x1, -NaN) == true
; run: %fcmp_ueq_f64(-NaN:0x1, -NaN) == true
; run: %fcmp_ueq_f64(-NaN:0x1, +NaN) == true
; run: %fcmp_ueq_f64(+NaN:0x800000000001, +NaN:0x800000000001) == true
; run: %fcmp_ueq_f64(-NaN:0x800000000001, -NaN:0x800000000001) == true
; run: %fcmp_ueq_f64(+NaN:0x800000000001, -NaN:0x800000000001) == true
; run: %fcmp_ueq_f64(-NaN:0x800000000001, +NaN:0x800000000001) == true
; run: %fcmp_ueq_f64(+NaN:0x800000000001, +NaN) == true
; run: %fcmp_ueq_f64(+NaN:0x800000000001, -NaN) == true
; run: %fcmp_ueq_f64(-NaN:0x800000000001, -NaN) == true
; run: %fcmp_ueq_f64(-NaN:0x800000000001, +NaN) == true
; sNaN's
; run: %fcmp_ueq_f64(+sNaN:0x1, +sNaN:0x1) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(+sNaN:0x1, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, +sNaN:0x1) == true
; run: %fcmp_ueq_f64(+sNaN:0x1, -0x1.0) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, -0x1.0) == true
; run: %fcmp_ueq_f64(+sNaN:0x1, 0x1.0) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, 0x1.0) == true
; run: %fcmp_ueq_f64(+sNaN:0x1, -0x0.0) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, -0x0.0) == true
; run: %fcmp_ueq_f64(+sNaN:0x1, 0x0.0) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, 0x0.0) == true
; run: %fcmp_ueq_f64(+sNaN:0x1, -Inf) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, -Inf) == true
; run: %fcmp_ueq_f64(+sNaN:0x1, Inf) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, Inf) == true
; run: %fcmp_ueq_f64(-0x0.0, +sNaN:0x1) == true
; run: %fcmp_ueq_f64(-0x0.0, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(0x0.0, +sNaN:0x1) == true
; run: %fcmp_ueq_f64(0x0.0, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(-Inf, +sNaN:0x1) == true
; run: %fcmp_ueq_f64(-Inf, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(Inf, +sNaN:0x1) == true
; run: %fcmp_ueq_f64(Inf, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(+sNaN:0x1, +NaN:0x1) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, -NaN:0x1) == true
; run: %fcmp_ueq_f64(+sNaN:0x1, -NaN:0x1) == true
; run: %fcmp_ueq_f64(-sNaN:0x1, +NaN:0x1) == true
; run: %fcmp_ueq_f64(+NaN:0x1, +sNaN:0x1) == true
; run: %fcmp_ueq_f64(-NaN:0x1, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(-NaN:0x1, +sNaN:0x1) == true
; run: %fcmp_ueq_f64(+NaN:0x1, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(+sNaN:0x800000000001, +sNaN:0x800000000001) == true
; run: %fcmp_ueq_f64(-sNaN:0x800000000001, -sNaN:0x800000000001) == true
; run: %fcmp_ueq_f64(+sNaN:0x800000000001, -sNaN:0x800000000001) == true
; run: %fcmp_ueq_f64(-sNaN:0x800000000001, +sNaN:0x800000000001) == true
; run: %fcmp_ueq_f64(+sNaN:0x800000000001, +sNaN:0x1) == true
; run: %fcmp_ueq_f64(+sNaN:0x800000000001, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(-sNaN:0x800000000001, -sNaN:0x1) == true
; run: %fcmp_ueq_f64(-sNaN:0x800000000001, +sNaN:0x1) == true