[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