mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-31 10:34:17 +00:00
Fix shl to produce the correct result when the bitwidth is > 64 and the
shift amount is 0. Previously this code would do a lshr by the bit width which can lead to incorrect results. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@37010 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
45d6764ca1
commit
92c7283500
@ -1199,6 +1199,12 @@ APInt APInt::shl(uint32_t shiftAmt) const {
|
||||
if (shiftAmt == BitWidth)
|
||||
return APInt(BitWidth, 0);
|
||||
|
||||
// If none of the bits are shifted out, the result is *this. This avoids a
|
||||
// lshr by the words size in the loop below which can produce incorrect
|
||||
// results. It also avoids the expensive computation below for a common case.
|
||||
if (shiftAmt == 0)
|
||||
return *this;
|
||||
|
||||
// Create some space for the result.
|
||||
uint64_t * val = new uint64_t[getNumWords()];
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user