summaryrefslogtreecommitdiffstats
path: root/llvm/test/Bitcode/upgrade-subprogram.ll.bc
diff options
context:
space:
mode:
authorSanjay Patel <spatel@rotateright.com>2019-08-02 17:39:32 +0000
committerSanjay Patel <spatel@rotateright.com>2019-08-02 17:39:32 +0000
commit9ce5f41851fe8016b6495ef514d772c6bc72cad2 (patch)
tree30e14bef9efe906e33746eaadd896b02c691a5cd /llvm/test/Bitcode/upgrade-subprogram.ll.bc
parent6722923c38839bb6ba9d3ff0d9ba3be5eaef1708 (diff)
downloadbcm5719-llvm-9ce5f41851fe8016b6495ef514d772c6bc72cad2.tar.gz
bcm5719-llvm-9ce5f41851fe8016b6495ef514d772c6bc72cad2.zip
[InstCombine] fold cmp+select using select operand equivalence
As discussed in PR42696: https://bugs.llvm.org/show_bug.cgi?id=42696 ...but won't help that case yet. We have an odd situation where a select operand equivalence fold was implemented in InstSimplify when it could have been done more generally in InstCombine if we allow dropping of {nsw,nuw,exact} from a binop operand. Here's an example: https://rise4fun.com/Alive/Xplr %cmp = icmp eq i32 %x, 2147483647 %add = add nsw i32 %x, 1 %sel = select i1 %cmp, i32 -2147483648, i32 %add => %sel = add i32 %x, 1 I've left the InstSimplify code in place for now, but my guess is that we'd prefer to remove that as a follow-up to save on code duplication and compile-time. Differential Revision: https://reviews.llvm.org/D65576 llvm-svn: 367695
Diffstat (limited to 'llvm/test/Bitcode/upgrade-subprogram.ll.bc')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud