diff options
author | Duncan Sands <baldrick@free.fr> | 2008-05-19 09:27:24 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2008-05-19 09:27:24 +0000 |
commit | eec7a3c071c79cabeabafd97c23d2dd4247fb66b (patch) | |
tree | 7d49fef332cb1b7f554afdd7af2c8ef86a725aac /llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp | |
parent | 8bd151d19463455572842261c14724b319e3b329 (diff) | |
download | bcm5719-llvm-eec7a3c071c79cabeabafd97c23d2dd4247fb66b.tar.gz bcm5719-llvm-eec7a3c071c79cabeabafd97c23d2dd4247fb66b.zip |
Fix PR2341 - when the length is 4 use an i32 not
an i16! Cleaned up trailing whitespace while there.
llvm-svn: 51240
Diffstat (limited to 'llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp')
-rw-r--r-- | llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp | 18 |
1 files changed, 10 insertions, 8 deletions
diff --git a/llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp b/llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp index 2b5b2b05b2c..cb90bdc912a 100644 --- a/llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp +++ b/llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp @@ -731,17 +731,17 @@ struct VISIBILITY_HIDDEN MemCmpOpt : public LibCallOptimization { !isa<PointerType>(FT->getParamType(1)) || FT->getReturnType() != Type::Int32Ty) return 0; - + Value *LHS = CI->getOperand(1), *RHS = CI->getOperand(2); - + if (LHS == RHS) // memcmp(s,s,x) -> 0 return Constant::getNullValue(CI->getType()); - + // Make sure we have a constant length. ConstantInt *LenC = dyn_cast<ConstantInt>(CI->getOperand(3)); if (!LenC) return 0; uint64_t Len = LenC->getZExtValue(); - + if (Len == 0) // memcmp(s1,s2,0) -> 0 return Constant::getNullValue(CI->getType()); @@ -750,18 +750,20 @@ struct VISIBILITY_HIDDEN MemCmpOpt : public LibCallOptimization { Value *RHSV = B.CreateLoad(CastToCStr(RHS, B), "rhsv"); return B.CreateZExt(B.CreateSub(LHSV, RHSV, "chardiff"), CI->getType()); } - + // memcmp(S1,S2,2) != 0 -> (*(short*)LHS ^ *(short*)RHS) != 0 // memcmp(S1,S2,4) != 0 -> (*(int*)LHS ^ *(int*)RHS) != 0 if ((Len == 2 || Len == 4) && IsOnlyUsedInZeroEqualityComparison(CI)) { - LHS = B.CreateBitCast(LHS, PointerType::getUnqual(Type::Int16Ty), "tmp"); - RHS = B.CreateBitCast(RHS, LHS->getType(), "tmp"); + const Type *PTy = PointerType::getUnqual(Len == 2 ? + Type::Int16Ty : Type::Int32Ty); + LHS = B.CreateBitCast(LHS, PTy, "tmp"); + RHS = B.CreateBitCast(RHS, PTy, "tmp"); LoadInst *LHSV = B.CreateLoad(LHS, "lhsv"); LoadInst *RHSV = B.CreateLoad(RHS, "rhsv"); LHSV->setAlignment(1); RHSV->setAlignment(1); // Unaligned loads. return B.CreateZExt(B.CreateXor(LHSV, RHSV, "shortdiff"), CI->getType()); } - + return 0; } }; |