Do not invoke UB in BigInt shr operations

Shifting a value of type T by an amount that's greater or equal to the
size of the type itself is UB.

Spotted by @tgschultz
This commit is contained in:
LemonBoy
2019-04-26 15:57:47 +02:00
committed by Andrew Kelley
parent 4df2f3d74f
commit 9ec4ccc68f
2 changed files with 5 additions and 3 deletions

View File

@@ -1395,7 +1395,7 @@ void bigint_shr(BigInt *dest, const BigInt *op1, const BigInt *op2) {
uint64_t shift_amt = bigint_as_unsigned(op2);
if (op1->digit_count == 1) {
dest->data.digit = op1_digits[0] >> shift_amt;
dest->data.digit = (shift_amt < 64) ? op1_digits[0] >> shift_amt : 0;
dest->digit_count = 1;
dest->is_negative = op1->is_negative;
bigint_normalize(dest);