diff options
author | Craig Topper <craig.topper@sifive.com> | 2024-08-16 09:21:11 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-08-16 09:21:11 -0700 |
commit | 7afb51e035709e7f2532452054a39fe968444504 (patch) | |
tree | f4884eac4c235c7d1643f443aa3d9d575339546b /llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp | |
parent | 1164e4aef2844ac3d35153ffe6376db9abda704a (diff) | |
download | llvm-7afb51e035709e7f2532452054a39fe968444504.zip llvm-7afb51e035709e7f2532452054a39fe968444504.tar.gz llvm-7afb51e035709e7f2532452054a39fe968444504.tar.bz2 |
[SelectionDAG][X86] Add SelectionDAG::getSignedConstant and use it in a few places. (#104555)
PR #80309 proposes to have users of APInt's uint64_t
constructor opt-in to implicit truncation. Currently, that patch
requires SelectionDAG::getConstant to opt-in.
This patch adds getSignedConstant so we can start fixing some of the
cases that require implicit truncation.
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp index 7bf90ce..2401bb5 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp @@ -1747,6 +1747,15 @@ SDValue SelectionDAG::getConstant(const ConstantInt &Val, const SDLoc &DL, return Result; } +SDValue SelectionDAG::getSignedConstant(int64_t Val, const SDLoc &DL, EVT VT, + bool isT, bool isO) { + unsigned Size = VT.getScalarSizeInBits(); + assert( + isIntN(Size, Val) && + "getSignedConstant with a int64_t value that doesn't fit in the type!"); + return getConstant(APInt(Size, Val, true), DL, VT, isT, isO); +} + SDValue SelectionDAG::getAllOnesConstant(const SDLoc &DL, EVT VT, bool IsTarget, bool IsOpaque) { return getConstant(APInt::getAllOnes(VT.getScalarSizeInBits()), DL, VT, |