diff options
author | Mon P Wang <wangmp@apple.com> | 2011-10-26 00:34:48 +0000 |
---|---|---|
committer | Mon P Wang <wangmp@apple.com> | 2011-10-26 00:34:48 +0000 |
commit | 6ebf401412484c3d741a0f74c61cad7516d7ad8c (patch) | |
tree | 971c08225246e8e18fbaaa1f3a20f14175375a34 /llvm/lib | |
parent | 0ed5747220a81336a111fa7702b5957c60b91bd4 (diff) | |
download | llvm-6ebf401412484c3d741a0f74c61cad7516d7ad8c.zip llvm-6ebf401412484c3d741a0f74c61cad7516d7ad8c.tar.gz llvm-6ebf401412484c3d741a0f74c61cad7516d7ad8c.tar.bz2 |
The bitcode reader can create an shuffle with a place holder mask which it will
fix up later. For this special case, allow such a mask to be considered valid.
<rdar://problem/8622574>
llvm-svn: 142992
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/VMCore/Instructions.cpp | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/llvm/lib/VMCore/Instructions.cpp b/llvm/lib/VMCore/Instructions.cpp index b3a7205..c8dcdc8 100644 --- a/llvm/lib/VMCore/Instructions.cpp +++ b/llvm/lib/VMCore/Instructions.cpp @@ -1576,10 +1576,17 @@ bool ShuffleVectorInst::isValidOperands(const Value *V1, const Value *V2, return false; } } - } - else if (!isa<UndefValue>(Mask) && !isa<ConstantAggregateZero>(Mask)) + } else if (!isa<UndefValue>(Mask) && !isa<ConstantAggregateZero>(Mask)) { + // The bitcode reader can create a place holder for a forward reference + // used as the shuffle mask. When this occurs, the shuffle mask will + // fall into this case and fail. To avoid this error, do this bit of + // ugliness to allow such a mask pass. + if (const ConstantExpr* CE = dyn_cast<ConstantExpr>(Mask)) { + if (CE->getOpcode() == Instruction::UserOp1) + return true; + } return false; - + } return true; } |