llvm-project/llvm/test/Transforms/MergeICmps/X86
Clement Courbet 735e6c888e [MergeICmps] Fix missing split.
We were not correctly splitting a blocks for chains of length 1.

Before that change, additional instructions for blocks in chains of
length 1 were not split off from the block before removing (this was
done correctly for chains of longer size).
If this first block contained an instruction referenced elsewhere,
deleting the block, would result in invalidation of the produced value.

This caused a miscompile which motivated D92297 (before D17993,
nonnull and dereferenceable attributed were not added so MergeICmps were
not triggered.) The new test gep-references-bb.ll demonstrate the issue.

The regression was introduced in
rG0efadbbcdeb82f5c14f38fbc2826107063ca48b2.

This supersedes D92364.

Test case by MaskRay (Fangrui Song).

Differential Revision: https://reviews.llvm.org/D92375
2020-12-01 16:50:55 +01:00
..
alias-merge-blocks.ll
atomic.ll
entry-block-shuffled.ll
gep-references-bb.ll [MergeICmps] Fix missing split. 2020-12-01 16:50:55 +01:00
gep-used-outside.ll
int64-and-ptr.ll
last-block-produce-no-value.ll
lit.local.cfg
multiple-blocks-does-work.ll
pair-int32-int32.ll
pr36557.ll
pr41917.ll
split-block-does-work.ll
tuple-four-int8.ll
two-complex-bb.ll
volatile.ll