summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/R600/R600ISelLowering.cpp
diff options
context:
space:
mode:
authorVincent Lejeune <vljn@ovi.com>2013-12-10 14:43:31 +0000
committerVincent Lejeune <vljn@ovi.com>2013-12-10 14:43:31 +0000
commitcc0ea74c7b6ede4c91f7bcfdedb5f1a011171c72 (patch)
tree06935964ce6aab7043d90d902c1a6bebae15edd3 /llvm/lib/Target/R600/R600ISelLowering.cpp
parentf92d64d160eb66c12c2fa46e88228cf22c245d49 (diff)
downloadbcm5719-llvm-cc0ea74c7b6ede4c91f7bcfdedb5f1a011171c72.tar.gz
bcm5719-llvm-cc0ea74c7b6ede4c91f7bcfdedb5f1a011171c72.zip
R600: Fix an infinite loop when trying to reorganize export/tex vector input
llvm-svn: 196923
Diffstat (limited to 'llvm/lib/Target/R600/R600ISelLowering.cpp')
-rw-r--r--llvm/lib/Target/R600/R600ISelLowering.cpp13
1 files changed, 8 insertions, 5 deletions
diff --git a/llvm/lib/Target/R600/R600ISelLowering.cpp b/llvm/lib/Target/R600/R600ISelLowering.cpp
index 1155c2a760a..21a2b0dd170 100644
--- a/llvm/lib/Target/R600/R600ISelLowering.cpp
+++ b/llvm/lib/Target/R600/R600ISelLowering.cpp
@@ -1442,17 +1442,20 @@ static SDValue ReorganizeVector(SelectionDAG &DAG, SDValue VectorEntry,
VectorEntry.getOperand(3)
};
bool isUnmovable[4] = { false, false, false, false };
- for (unsigned i = 0; i < 4; i++)
+ for (unsigned i = 0; i < 4; i++) {
RemapSwizzle[i] = i;
+ if (NewBldVec[i].getOpcode() == ISD::EXTRACT_VECTOR_ELT) {
+ unsigned Idx = dyn_cast<ConstantSDNode>(NewBldVec[i].getOperand(1))
+ ->getZExtValue();
+ if (i == Idx)
+ isUnmovable[Idx] = true;
+ }
+ }
for (unsigned i = 0; i < 4; i++) {
if (NewBldVec[i].getOpcode() == ISD::EXTRACT_VECTOR_ELT) {
unsigned Idx = dyn_cast<ConstantSDNode>(NewBldVec[i].getOperand(1))
->getZExtValue();
- if (i == Idx) {
- isUnmovable[Idx] = true;
- continue;
- }
if (isUnmovable[Idx])
continue;
// Swap i and Idx
OpenPOWER on IntegriCloud