[llvm] 16d2065 - [InstCombine] Add ub-safe negation patterns (PR27817)
Simon Pilgrim via llvm-commits
llvm-commits at lists.llvm.org
Mon Mar 23 05:48:08 PDT 2020
Author: Simon Pilgrim
Date: 2020-03-23T12:47:32Z
New Revision: 16d2065cfc885633c62e772393cd1b56f453fa3b
URL: https://github.com/llvm/llvm-project/commit/16d2065cfc885633c62e772393cd1b56f453fa3b
DIFF: https://github.com/llvm/llvm-project/commit/16d2065cfc885633c62e772393cd1b56f453fa3b.diff
LOG: [InstCombine] Add ub-safe negation patterns (PR27817)
Added:
Modified:
llvm/test/Transforms/InstCombine/select.ll
Removed:
################################################################################
diff --git a/llvm/test/Transforms/InstCombine/select.ll b/llvm/test/Transforms/InstCombine/select.ll
index 0f26a93a7bae..20b6dd1a990c 100644
--- a/llvm/test/Transforms/InstCombine/select.ll
+++ b/llvm/test/Transforms/InstCombine/select.ll
@@ -1348,6 +1348,29 @@ define i32 @PR27137(i32 %a) {
ret i32 %s1
}
+; ub-safe negation pattern
+define i32 @PR27817(i32 %x) {
+; CHECK-LABEL: @PR27817(
+; CHECK-NEXT: [[SUB:%.*]] = sub i32 0, [[X:%.*]]
+; CHECK-NEXT: ret i32 [[SUB]]
+;
+ %cmp = icmp eq i32 %x, -2147483648
+ %sub = sub i32 0, %x
+ %sel = select i1 %cmp, i32 -2147483648, i32 %sub
+ ret i32 %sel
+}
+
+define i32 @PR27817_nsw(i32 %x) {
+; CHECK-LABEL: @PR27817_nsw(
+; CHECK-NEXT: [[SUB:%.*]] = sub i32 0, [[X:%.*]]
+; CHECK-NEXT: ret i32 [[SUB]]
+;
+ %cmp = icmp eq i32 %x, -2147483648
+ %sub = sub nsw i32 0, %x
+ %sel = select i1 %cmp, i32 -2147483648, i32 %sub
+ ret i32 %sel
+}
+
define i32 @select_icmp_slt0_xor(i32 %x) {
; CHECK-LABEL: @select_icmp_slt0_xor(
; CHECK-NEXT: [[TMP1:%.*]] = or i32 [[X:%.*]], -2147483648
More information about the llvm-commits
mailing list