diff options
author | Chris Lattner <sabre@nondot.org> | 2008-03-02 05:28:33 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-03-02 05:28:33 +0000 |
commit | e7690b01073b4832cb5df60e6bc8a0537cd216ba (patch) | |
tree | 6c29f63d79c9c38e79d35ce7030f6f20c35ff073 /lib/VMCore/Instructions.cpp | |
parent | a5f0bc07fa0d57a199c32d3b87bc695a30acaed8 (diff) | |
download | external_llvm-e7690b01073b4832cb5df60e6bc8a0537cd216ba.tar.gz external_llvm-e7690b01073b4832cb5df60e6bc8a0537cd216ba.tar.bz2 external_llvm-e7690b01073b4832cb5df60e6bc8a0537cd216ba.zip |
Add a new ShuffleVectorInst::getMaskValue method.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47813 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore/Instructions.cpp')
-rw-r--r-- | lib/VMCore/Instructions.cpp | 30 |
1 files changed, 24 insertions, 6 deletions
diff --git a/lib/VMCore/Instructions.cpp b/lib/VMCore/Instructions.cpp index c0b3413da3..dfd3b830ca 100644 --- a/lib/VMCore/Instructions.cpp +++ b/lib/VMCore/Instructions.cpp @@ -1350,16 +1350,34 @@ ShuffleVectorInst::ShuffleVectorInst(Value *V1, Value *V2, Value *Mask, bool ShuffleVectorInst::isValidOperands(const Value *V1, const Value *V2, const Value *Mask) { - if (!isa<VectorType>(V1->getType())) return false; - if (V1->getType() != V2->getType()) return false; - if (!isa<VectorType>(Mask->getType()) || - cast<VectorType>(Mask->getType())->getElementType() != Type::Int32Ty || - cast<VectorType>(Mask->getType())->getNumElements() != - cast<VectorType>(V1->getType())->getNumElements()) + if (!isa<VectorType>(V1->getType()) || + V1->getType() != V2->getType()) + return false; + + const VectorType *MaskTy = dyn_cast<VectorType>(Mask->getType()); + if (!isa<Constant>(Mask) || MaskTy == 0 || + MaskTy->getElementType() != Type::Int32Ty || + MaskTy->getNumElements() != + cast<VectorType>(V1->getType())->getNumElements()) return false; return true; } +/// getMaskValue - Return the index from the shuffle mask for the specified +/// output result. This is either -1 if the element is undef or a number less +/// than 2*numelements. +int ShuffleVectorInst::getMaskValue(unsigned i) const { + const Constant *Mask = cast<Constant>(getOperand(2)); + if (isa<UndefValue>(Mask)) return -1; + if (isa<ConstantAggregateZero>(Mask)) return 0; + const ConstantVector *MaskCV = cast<ConstantVector>(Mask); + assert(i < MaskCV->getNumOperands() && "Index out of range"); + + if (isa<UndefValue>(MaskCV->getOperand(i))) + return -1; + return cast<ConstantInt>(MaskCV->getOperand(i))->getZExtValue(); +} + //===----------------------------------------------------------------------===// // BinaryOperator Class |