summaryrefslogtreecommitdiffstats
path: root/vendor/libm-0.1.4/src/math/ilogbf.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-18 02:49:42 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-18 02:49:42 +0000
commit837b550238aa671a591ccf282dddeab29cadb206 (patch)
tree914b6b8862bace72bd3245ca184d374b08d8a672 /vendor/libm-0.1.4/src/math/ilogbf.rs
parentAdding debian version 1.70.0+dfsg2-1. (diff)
downloadrustc-837b550238aa671a591ccf282dddeab29cadb206.tar.xz
rustc-837b550238aa671a591ccf282dddeab29cadb206.zip
Merging upstream version 1.71.1+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'vendor/libm-0.1.4/src/math/ilogbf.rs')
-rw-r--r--vendor/libm-0.1.4/src/math/ilogbf.rs31
1 files changed, 31 insertions, 0 deletions
diff --git a/vendor/libm-0.1.4/src/math/ilogbf.rs b/vendor/libm-0.1.4/src/math/ilogbf.rs
new file mode 100644
index 000000000..b384fa4b2
--- /dev/null
+++ b/vendor/libm-0.1.4/src/math/ilogbf.rs
@@ -0,0 +1,31 @@
+const FP_ILOGBNAN: i32 = -1 - 0x7fffffff;
+const FP_ILOGB0: i32 = FP_ILOGBNAN;
+
+pub fn ilogbf(x: f32) -> i32 {
+ let mut i = x.to_bits();
+ let e = ((i >> 23) & 0xff) as i32;
+
+ if e == 0 {
+ i <<= 9;
+ if i == 0 {
+ force_eval!(0.0 / 0.0);
+ return FP_ILOGB0;
+ }
+ /* subnormal x */
+ let mut e = -0x7f;
+ while (i >> 31) == 0 {
+ e -= 1;
+ i <<= 1;
+ }
+ e
+ } else if e == 0xff {
+ force_eval!(0.0 / 0.0);
+ if (i << 9) != 0 {
+ FP_ILOGBNAN
+ } else {
+ i32::max_value()
+ }
+ } else {
+ e - 0x7f
+ }
+}