diff options
| author | Adam Nemet <anemet@apple.com> | 2014-03-24 16:52:08 +0000 | 
|---|---|---|
| committer | Adam Nemet <anemet@apple.com> | 2014-03-24 16:52:08 +0000 | 
| commit | b47372f555fab3652c2bc43e50ba8a7707fe67b7 (patch) | |
| tree | 5aba876281acb381d9b59b518fc39272bc8e02f5 /llvm/lib/Target/TargetMachine.cpp | |
| parent | 1d77a8203be147ae41692fecad4c41035dbe69a1 (diff) | |
| download | bcm5719-llvm-b47372f555fab3652c2bc43e50ba8a7707fe67b7.tar.gz bcm5719-llvm-b47372f555fab3652c2bc43e50ba8a7707fe67b7.zip | |
[X86] Fix non-determinism in LowerVectorAllZeroTest
This can be observed with the old testcase of CodeGen/X86/pr12312.ll:
47c47
<       vorps   %ymm0, %ymm1, %ymm0
---
>       vorps   %ymm1, %ymm0, %ymm0
97c97
<       vorps   %ymm1, %ymm0, %ymm0
---
>       vorps   %ymm0, %ymm1, %ymm0
The vector VecIns is populated with all the values from VecInMap. This is done
while iterating VecInMap.  VecInMap uses a hash of pointer values so the
resulting order can vary depending on the memory layout.
The fix is to populate the vector VecIns earlier as VecInMap is populated.
This is done in DAG traversal order.
Fixes <rdar://problem/16398806>
llvm-svn: 204623
Diffstat (limited to 'llvm/lib/Target/TargetMachine.cpp')
0 files changed, 0 insertions, 0 deletions

