diff options
author | Mon P Wang <wangmp@apple.com> | 2009-12-02 04:59:58 +0000 |
---|---|---|
committer | Mon P Wang <wangmp@apple.com> | 2009-12-02 04:59:58 +0000 |
commit | 69a008075b29fbe0644ccbeecf1418ef8cca5e24 (patch) | |
tree | a2224d38112c7449a818b5eb4f9d814e9a651add | |
parent | e3a18de4f66a90040fb67495578652e36a886af5 (diff) | |
download | external_llvm-69a008075b29fbe0644ccbeecf1418ef8cca5e24.zip external_llvm-69a008075b29fbe0644ccbeecf1418ef8cca5e24.tar.gz external_llvm-69a008075b29fbe0644ccbeecf1418ef8cca5e24.tar.bz2 |
Fixed an assertion failure for tracking sext of a vector of integers
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@90290 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Analysis/ValueTracking.cpp | 2 | ||||
-rw-r--r-- | test/Transforms/InstCombine/sext-2.ll | 14 |
2 files changed, 15 insertions, 1 deletions
diff --git a/lib/Analysis/ValueTracking.cpp b/lib/Analysis/ValueTracking.cpp index 31d3ccc..22c6e3b 100644 --- a/lib/Analysis/ValueTracking.cpp +++ b/lib/Analysis/ValueTracking.cpp @@ -659,7 +659,7 @@ unsigned llvm::ComputeNumSignBits(Value *V, const TargetData *TD, switch (Operator::getOpcode(V)) { default: break; case Instruction::SExt: - Tmp = TyBits-cast<IntegerType>(U->getOperand(0)->getType())->getBitWidth(); + Tmp = TyBits - U->getOperand(0)->getType()->getScalarSizeInBits(); return ComputeNumSignBits(U->getOperand(0), TD, Depth+1) + Tmp; case Instruction::AShr: diff --git a/test/Transforms/InstCombine/sext-2.ll b/test/Transforms/InstCombine/sext-2.ll new file mode 100644 index 0000000..39d4a3c --- /dev/null +++ b/test/Transforms/InstCombine/sext-2.ll @@ -0,0 +1,14 @@ +; Checks to see that instcombine can handle a sign extension of i1 + +; RUN: opt < %s -instcombine -S | FileCheck %s + +define void @test(<2 x i16> %srcA, <2 x i16> %srcB, <2 x i16>* %dst) nounwind { +entry: +; CHECK-NOT: tmask +; CHECK: ret + %cmp = icmp eq <2 x i16> %srcB, %srcA; + %sext = sext <2 x i1> %cmp to <2 x i16>; + %tmask = ashr <2 x i16> %sext, <i16 15, i16 15> ; + store <2 x i16> %tmask, <2 x i16>* %dst; + ret void +} |