forked from OSchip/llvm-project
735e6c888e
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 |
||
---|---|---|
.. | ||
alias-merge-blocks.ll | ||
atomic.ll | ||
entry-block-shuffled.ll | ||
gep-references-bb.ll | ||
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 |