diff options
author | 2015-03-11 15:02:31 +0000 | |
---|---|---|
committer | 2015-03-11 15:02:32 +0000 | |
commit | 356286f989941ac495417195e4129aaceaf36a83 (patch) | |
tree | f6b68ff38722dc91bd0de2387609ee0ce950e0ce /compiler/optimizing/nodes.h | |
parent | 31df246d330c45f5691e226d176d0c59450f8435 (diff) | |
parent | 234d69d075d1608f80adb647f7935077b62b6376 (diff) |
Merge "Revert "Revert "[optimizing] Enable x86 long support."""
Diffstat (limited to 'compiler/optimizing/nodes.h')
-rw-r--r-- | compiler/optimizing/nodes.h | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/compiler/optimizing/nodes.h b/compiler/optimizing/nodes.h index 942aa2374b..d4498a6d42 100644 --- a/compiler/optimizing/nodes.h +++ b/compiler/optimizing/nodes.h @@ -3310,8 +3310,19 @@ class HParallelMove : public HTemplateInstruction<0> { if (kIsDebugBuild) { if (instruction != nullptr) { for (size_t i = 0, e = moves_.Size(); i < e; ++i) { - DCHECK_NE(moves_.Get(i).GetInstruction(), instruction) - << "Doing parallel moves for the same instruction."; + if (moves_.Get(i).GetInstruction() == instruction) { + // Special case the situation where the move is for the spill slot + // of the instruction. + if ((GetPrevious() == instruction) + || ((GetPrevious() == nullptr) + && instruction->IsPhi() + && instruction->GetBlock() == GetBlock())) { + DCHECK_NE(destination.GetKind(), moves_.Get(i).GetDestination().GetKind()) + << "Doing parallel moves for the same instruction."; + } else { + DCHECK(false) << "Doing parallel moves for the same instruction."; + } + } } } for (size_t i = 0, e = moves_.Size(); i < e; ++i) { |