mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-29 14:40:25 +00:00
Fix a problem where shifting by 64-bits leads to incorrect results on PPC
but not on X86 becuase shift by word size is "undefined". git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@34825 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
9f8e50d4ed
commit
36184ed4cd
@ -938,7 +938,10 @@ APInt &APInt::sext(uint32_t width) {
|
||||
if (wordsBefore == wordsAfter) {
|
||||
uint32_t newWordBits = width % APINT_BITS_PER_WORD;
|
||||
// The extension is contained to the wordsBefore-1th word.
|
||||
uint64_t mask = (~0ULL >> (APINT_BITS_PER_WORD - newWordBits)) << wordBits;
|
||||
uint64_t mask = ~0ULL;
|
||||
if (newWordBits)
|
||||
mask >>= APINT_BITS_PER_WORD - newWordBits;
|
||||
mask <<= wordBits;
|
||||
if (wordsBefore == 1)
|
||||
VAL |= mask;
|
||||
else
|
||||
|
Loading…
Reference in New Issue
Block a user