summaryrefslogtreecommitdiffstats
path: root/third_party/rust/libm/src/math/frexp.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /third_party/rust/libm/src/math/frexp.rs
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'third_party/rust/libm/src/math/frexp.rs')
-rw-r--r--third_party/rust/libm/src/math/frexp.rs20
1 files changed, 20 insertions, 0 deletions
diff --git a/third_party/rust/libm/src/math/frexp.rs b/third_party/rust/libm/src/math/frexp.rs
new file mode 100644
index 0000000000..badad786aa
--- /dev/null
+++ b/third_party/rust/libm/src/math/frexp.rs
@@ -0,0 +1,20 @@
+pub fn frexp(x: f64) -> (f64, i32) {
+ let mut y = x.to_bits();
+ let ee = ((y >> 52) & 0x7ff) as i32;
+
+ if ee == 0 {
+ if x != 0.0 {
+ let x1p64 = f64::from_bits(0x43f0000000000000);
+ let (x, e) = frexp(x * x1p64);
+ return (x, e - 64);
+ }
+ return (x, 0);
+ } else if ee == 0x7ff {
+ return (x, 0);
+ }
+
+ let e = ee - 0x3fe;
+ y &= 0x800fffffffffffff;
+ y |= 0x3fe0000000000000;
+ return (f64::from_bits(y), e);
+}