mirror of
https://github.com/RPCSX/llvm.git
synced 2025-02-14 01:40:53 +00:00
[CodeGenPrepare] Compress a pair. No functional change.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@243759 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
8ae0800ae1
commit
3973e4b71b
@ -109,11 +109,7 @@ static cl::opt<bool> StressExtLdPromotion(
|
||||
|
||||
namespace {
|
||||
typedef SmallPtrSet<Instruction *, 16> SetOfInstrs;
|
||||
struct TypeIsSExt {
|
||||
Type *Ty;
|
||||
bool IsSExt;
|
||||
TypeIsSExt(Type *Ty, bool IsSExt) : Ty(Ty), IsSExt(IsSExt) {}
|
||||
};
|
||||
typedef PointerIntPair<Type *, 1, bool> TypeIsSExt;
|
||||
typedef DenseMap<Instruction *, TypeIsSExt> InstrToOrigTy;
|
||||
class TypePromotionTransaction;
|
||||
|
||||
@ -2433,8 +2429,8 @@ bool TypePromotionHelper::canGetThrough(const Instruction *Inst,
|
||||
// #1 get the type of the operand and check the kind of the extended bits.
|
||||
const Type *OpndType;
|
||||
InstrToOrigTy::const_iterator It = PromotedInsts.find(Opnd);
|
||||
if (It != PromotedInsts.end() && It->second.IsSExt == IsSExt)
|
||||
OpndType = It->second.Ty;
|
||||
if (It != PromotedInsts.end() && It->second.getInt() == IsSExt)
|
||||
OpndType = It->second.getPointer();
|
||||
else if ((IsSExt && isa<SExtInst>(Opnd)) || (!IsSExt && isa<ZExtInst>(Opnd)))
|
||||
OpndType = Opnd->getOperand(0)->getType();
|
||||
else
|
||||
|
Loading…
x
Reference in New Issue
Block a user