[libc-commits] [libc] [libc][NFC] Simplify `BigInt::mul` (PR #84468)
via libc-commits
libc-commits at lists.llvm.org
Fri Mar 8 04:08:37 PST 2024
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-libc
Author: Guillaume Chatelet (gchatelet)
<details>
<summary>Changes</summary>
---
Full diff: https://github.com/llvm/llvm-project/pull/84468.diff
1 Files Affected:
- (modified) libc/src/__support/UInt.h (+1-3)
``````````diff
diff --git a/libc/src/__support/UInt.h b/libc/src/__support/UInt.h
index cf0c5a669ae8dd..fadccf545006dd 100644
--- a/libc/src/__support/UInt.h
+++ b/libc/src/__support/UInt.h
@@ -262,15 +262,13 @@ struct BigInt {
// Returns the carry value produced by the multiplication operation.
LIBC_INLINE constexpr WordType mul(WordType x) {
BigInt<2 * WORD_SIZE, Signed, WordType> partial_sum(0);
- WordType carry = 0;
for (size_t i = 0; i < WORD_COUNT; ++i) {
NumberPair<WordType> prod = full_mul(val[i], x);
BigInt<2 * WORD_SIZE, Signed, WordType> tmp({prod.lo, prod.hi});
- carry += partial_sum.add(tmp);
+ const WordType carry = partial_sum.add(tmp);
val[i] = partial_sum.val[0];
partial_sum.val[0] = partial_sum.val[1];
partial_sum.val[1] = carry;
- carry = 0;
}
return partial_sum.val[1];
}
``````````
</details>
https://github.com/llvm/llvm-project/pull/84468
More information about the libc-commits
mailing list