From 04c4ab4a2a1f9fe311d9ad809a204d64bc2f5ad4 Mon Sep 17 00:00:00 2001 From: Ralf Jung Date: Sat, 31 Aug 2024 22:28:17 +0200 Subject: [PATCH] clean up internal comments about float semantics - remove an outdated FIXME - add reference to floating-point semantics issue Co-authored-by: Jubilee --- core/src/num/f16.rs | 1 + core/src/num/f32.rs | 5 +---- core/src/num/f64.rs | 5 +---- 3 files changed, 3 insertions(+), 8 deletions(-) diff --git a/core/src/num/f16.rs b/core/src/num/f16.rs index 9252e8c601558..da92da1086dab 100644 --- a/core/src/num/f16.rs +++ b/core/src/num/f16.rs @@ -435,6 +435,7 @@ impl f16 { // WASM, see llvm/llvm-project#96437). These are platforms bugs, and Rust will misbehave on // such platforms, but we can at least try to make things seem as sane as possible by being // careful here. + // see also https://github.com/rust-lang/rust/issues/114479 if self.is_infinite() { // Thus, a value may compare unequal to infinity, despite having a "full" exponent mask. FpCategory::Infinite diff --git a/core/src/num/f32.rs b/core/src/num/f32.rs index 2bc897224970d..885f7608a337e 100644 --- a/core/src/num/f32.rs +++ b/core/src/num/f32.rs @@ -662,10 +662,7 @@ impl f32 { // hardware flushes subnormals to zero. These are platforms bugs, and Rust will misbehave on // such hardware, but we can at least try to make things seem as sane as possible by being // careful here. - // - // FIXME(jubilee): Using x87 operations is never necessary in order to function - // on x86 processors for Rust-to-Rust calls, so this issue should not happen. - // Code generation should be adjusted to use non-C calling conventions, avoiding this. + // see also https://github.com/rust-lang/rust/issues/114479 if self.is_infinite() { // A value may compare unequal to infinity, despite having a "full" exponent mask. FpCategory::Infinite diff --git a/core/src/num/f64.rs b/core/src/num/f64.rs index b3f5be9fc8a46..28cc231ccc76d 100644 --- a/core/src/num/f64.rs +++ b/core/src/num/f64.rs @@ -660,10 +660,7 @@ impl f64 { // float semantics Rust relies on: x87 uses a too-large exponent, and some hardware flushes // subnormals to zero. These are platforms bugs, and Rust will misbehave on such hardware, // but we can at least try to make things seem as sane as possible by being careful here. - // - // FIXME(jubilee): Using x87 operations is never necessary in order to function - // on x86 processors for Rust-to-Rust calls, so this issue should not happen. - // Code generation should be adjusted to use non-C calling conventions, avoiding this. + // see also https://github.com/rust-lang/rust/issues/114479 // // Thus, a value may compare unequal to infinity, despite having a "full" exponent mask. // And it may not be NaN, as it can simply be an "overextended" finite value.