mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
Stop APInt::shl from generating llvm.trap
APInt::shl generated llvm.trap to guard against shifts greater than bit-width. This was already checked with an assert, and there was a special case for shifts equal to bit-width. Modify this check to catch shifts greater than or equal to bit-width, so llvm.trap isn't generated. Patch contributed by JF Bastien git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@166803 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ecc69a1d99
commit
b61054ff8f
@ -760,7 +760,7 @@ public:
|
|||||||
APInt shl(unsigned shiftAmt) const {
|
APInt shl(unsigned shiftAmt) const {
|
||||||
assert(shiftAmt <= BitWidth && "Invalid shift amount");
|
assert(shiftAmt <= BitWidth && "Invalid shift amount");
|
||||||
if (isSingleWord()) {
|
if (isSingleWord()) {
|
||||||
if (shiftAmt == BitWidth)
|
if (shiftAmt >= BitWidth)
|
||||||
return APInt(BitWidth, 0); // avoid undefined shift results
|
return APInt(BitWidth, 0); // avoid undefined shift results
|
||||||
return APInt(BitWidth, VAL << shiftAmt);
|
return APInt(BitWidth, VAL << shiftAmt);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user