From: Reid Spencer Date: Sat, 17 Feb 2007 22:38:07 +0000 (+0000) Subject: Fix some bugs in division logic. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=c72f28042b11a329db721b816fdee957f6aac9d4;p=oota-llvm.git Fix some bugs in division logic. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@34384 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Support/APInt.cpp b/lib/Support/APInt.cpp index 211bf90d8cf..69cbdc7a35e 100644 --- a/lib/Support/APInt.cpp +++ b/lib/Support/APInt.cpp @@ -980,7 +980,7 @@ static unsigned subMul(unsigned dest[], unsigned offset, unsigned carry = 0; unsigned j = 0; do { - uint64_t prod = ((uint64_t) x[j] & 0xffffffffL) * yl; + uint64_t prod = ((uint64_t) x[j] & 0xffffffffUL) * yl; unsigned prod_low = (unsigned) prod; unsigned prod_high = (unsigned) (prod >> 32); prod_low += carry; @@ -1104,7 +1104,8 @@ APInt APInt::udiv(const APInt& RHS) const { X = APIntOps::shl(Result, nshift); ++lhsWords; } - div((unsigned*)X.pVal, lhsWords * 2 - 1, (unsigned*)Y.pVal, rhsWords*2); + div((unsigned*)X.pVal, lhsWords * 2 - 1, + (unsigned*)(Y.isSingleWord()? &Y.VAL : Y.pVal), rhsWords*2); memset(Result.pVal, 0, Result.getNumWords() * 8); memcpy(Result.pVal, X.pVal + rhsWords, (lhsWords - rhsWords) * 8); } @@ -1154,7 +1155,8 @@ APInt APInt::urem(const APInt& RHS) const { APIntOps::shl(Y, nshift); APIntOps::shl(X, nshift); } - div((unsigned*)X.pVal, rhsWords*2-1, (unsigned*)Y.pVal, rhsWords*2); + div((unsigned*)X.pVal, rhsWords*2-1, + (unsigned*)(Y.isSingleWord()? &Y.VAL : Y.pVal), rhsWords*2); memset(Result.pVal, 0, Result.getNumWords() * 8); for (unsigned i = 0; i < rhsWords-1; ++i) Result.pVal[i] = (X.pVal[i] >> nshift) | (X.pVal[i+1] << (64 - nshift));