summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms
diff options
context:
space:
mode:
authorSven van Haastregt <sven.vanhaastregt@arm.com>2017-06-05 09:18:10 +0000
committerSven van Haastregt <sven.vanhaastregt@arm.com>2017-06-05 09:18:10 +0000
commit78819e0fd470e1f736891549491ef14f24c68fed (patch)
tree709bff390dac698360bff85dc3e3544c7981f86c /llvm/lib/Transforms
parent43e852fb79fe4a7bfca857d92b6b5d30c108cf45 (diff)
downloadbcm5719-llvm-78819e0fd470e1f736891549491ef14f24c68fed.tar.gz
bcm5719-llvm-78819e0fd470e1f736891549491ef14f24c68fed.zip
[InstCombine] Fix extractelement use before def
This fixes a bug that can cause extractelements with operands that haven't been defined yet to be inserted at a wrong point when optimising insertelements. Patch by Karl Hylen. Differential Revision: https://reviews.llvm.org/D33449 llvm-svn: 304701
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r--llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp b/llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp
index 7fc6774f184..abfa39ded99 100644
--- a/llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp
+++ b/llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp
@@ -440,7 +440,7 @@ static void replaceExtractElements(InsertElementInst *InsElt,
if (!OldExt || OldExt->getParent() != WideVec->getParent())
continue;
auto *NewExt = ExtractElementInst::Create(WideVec, OldExt->getOperand(1));
- NewExt->insertAfter(WideVec);
+ NewExt->insertAfter(OldExt);
IC.replaceInstUsesWith(*OldExt, NewExt);
}
}
OpenPOWER on IntegriCloud