[libc-commits] [libc] [libc][stdfix] Implement fxdivi functions (rdivi) (PR #154914)
via libc-commits
libc-commits at lists.llvm.org
Fri Sep 12 12:01:48 PDT 2025
================
@@ -224,6 +224,80 @@ idiv(T x, T y) {
return static_cast<XType>(result);
}
+LIBC_INLINE long accum nrstep(long accum d, long accum x0) {
+ auto v = x0 * (2.lk - (d * x0));
+ return v;
+}
+
+/* Divide the two integers and return a fixed_point value
+ *
+ * For reference, see:
+ * https://en.wikipedia.org/wiki/Division_algorithm#Newton%E2%80%93Raphson_division
+ * https://stackoverflow.com/a/9231996
+ */
+template <typename XType> LIBC_INLINE constexpr XType divi(int n, int d) {
+ // If the value of the second operand of the / operator is zero, the
+ // behavior is undefined. Ref: ISO/IEC TR 18037:2008(E) p.g. 16
+ LIBC_CRASH_ON_VALUE(d, 0);
+
+ if (LIBC_UNLIKELY(n == 0)) {
+ return FXRep<XType>::ZERO();
+ }
+ bool result_is_negative = (n < 0) ^ (d < 0);
+
+ unsigned int nv = static_cast<unsigned int>(n < 0 ? -n : n);
+ unsigned int dv = static_cast<unsigned int>(d < 0 ? -d : d);
+ unsigned int clz = cpp::countl_zero<unsigned int>(dv) - 1;
----------------
lntue wrote:
what happens when `d = INT_MIN`?
https://github.com/llvm/llvm-project/pull/154914
More information about the libc-commits
mailing list