forked from OSchip/llvm-project
eb46137daa
The entries in VectorizableTree are not necessarily ordered by their position in basic blocks. Collect them and order them by dominance so later instructions are guaranteed to be visited first. For instructions in different basic blocks, we only scan to the beginning of the block, so their order does not matter, as long as all instructions in a basic block are grouped together. Using dominance ensures a deterministic order. The modified test case contains an example where we compute a wrong spill cost (2) without this patch, even though there is no call between any instruction in the bundle. This seems to have limited practical impact, .e.g on X86 with a recent Intel Xeon CPU with -O3 -march=native -flto on MultiSource,SPEC2000,SPEC2006 there are no binary changes. Reviewers: craig.topper, RKSimon, xbolva00, ABataev, spatel Reviewed By: ABataev Differential Revision: https://reviews.llvm.org/D82444 |
||
---|---|---|
.. | ||
64-bit-vector.ll | ||
PR38339.ll | ||
accelerate-vector-functions.ll | ||
commute.ll | ||
ext-trunc.ll | ||
gather-cost.ll | ||
gather-reduce.ll | ||
gather-root.ll | ||
getelementptr.ll | ||
horizontal.ll | ||
invalid_type.ll | ||
lit.local.cfg | ||
load-store-q.ll | ||
matmul.ll | ||
minimum-sizes.ll | ||
mismatched-intrinsics.ll | ||
nontemporal.ll | ||
remarks.ll | ||
scalable-vector.ll | ||
sdiv-pow2.ll | ||
spillcost-di.ll | ||
spillcost-order.ll | ||
transpose.ll | ||
tsc-s352.ll |