diff options
| author | Michael Liao <michael.liao@intel.com> | 2012-08-15 03:49:59 +0000 | 
|---|---|---|
| committer | Michael Liao <michael.liao@intel.com> | 2012-08-15 03:49:59 +0000 | 
| commit | 69e172a6f0a888b579f277f7b2f75371bfb4acba (patch) | |
| tree | d9a98ed0682afced110eebb5a88ab922afad750e /llvm/lib | |
| parent | 58564d5aa6c1831bdf367b2736bb0aa5c4c86a77 (diff) | |
| download | bcm5719-llvm-69e172a6f0a888b579f277f7b2f75371bfb4acba.tar.gz bcm5719-llvm-69e172a6f0a888b579f277f7b2f75371bfb4acba.zip  | |
fix infinite loop in instcombine with more than 4GB memcpy
- memcpy size is wrongly truncated into 32-bit and treat 8GB memcpy is
  0-sized memcpy
- as 0-sized memcpy/memset is already removed before SimplifyMemTransfer
  and SimplifyMemSet in visitCallInst, replace 0 checking with
  assertions.
- replace getZExtValue() with getLimitedValue() according to
  Eli Friedman
llvm-svn: 161923
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp | 10 | 
1 files changed, 4 insertions, 6 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp b/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp index d34fab103fa..cbe1ca4ddce 100644 --- a/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp +++ b/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp @@ -51,8 +51,8 @@ Instruction *InstCombiner::SimplifyMemTransfer(MemIntrinsic *MI) {    // if the size is something we can handle with a single primitive load/store.    // A single load+store correctly handles overlapping memory in the memmove    // case. -  unsigned Size = MemOpLength->getZExtValue(); -  if (Size == 0) return MI;  // Delete this mem transfer. +  uint64_t Size = MemOpLength->getLimitedValue(); +  assert(Size && "0-sized memory transfering should be removed already.");    if (Size > 8 || (Size&(Size-1)))      return 0;  // If not 1/2/4/8 bytes, exit. @@ -133,11 +133,9 @@ Instruction *InstCombiner::SimplifyMemSet(MemSetInst *MI) {    ConstantInt *FillC = dyn_cast<ConstantInt>(MI->getValue());    if (!LenC || !FillC || !FillC->getType()->isIntegerTy(8))      return 0; -  uint64_t Len = LenC->getZExtValue(); +  uint64_t Len = LenC->getLimitedValue();    Alignment = MI->getAlignment(); - -  // If the length is zero, this is a no-op -  if (Len == 0) return MI; // memset(d,c,0,a) -> noop +  assert(Len && "0-sized memory setting should be removed already.");    // memset(s,c,n) -> store s, c (for n=1,2,4,8)    if (Len <= 8 && isPowerOf2_32((uint32_t)Len)) {  | 

