[llvm] 5c6cb61 - [SCCP] Add sub tests for NUW/NSW flag inference.
Florian Hahn via llvm-commits
llvm-commits at lists.llvm.org
Mon Jan 30 11:41:10 PST 2023
Author: Florian Hahn
Date: 2023-01-30T19:40:56Z
New Revision: 5c6cb61ad416a544e9260dcf5da26631675f5e4e
URL: https://github.com/llvm/llvm-project/commit/5c6cb61ad416a544e9260dcf5da26631675f5e4e
DIFF: https://github.com/llvm/llvm-project/commit/5c6cb61ad416a544e9260dcf5da26631675f5e4e.diff
LOG: [SCCP] Add sub tests for NUW/NSW flag inference.
Those tests add coverage for a miscompile with 024115ab14822a97c.
Added:
llvm/test/Transforms/SCCP/sub-nuw-nsw-flags.ll
Modified:
Removed:
################################################################################
diff --git a/llvm/test/Transforms/SCCP/sub-nuw-nsw-flags.ll b/llvm/test/Transforms/SCCP/sub-nuw-nsw-flags.ll
new file mode 100644
index 0000000000000..3b3cd663bc542
--- /dev/null
+++ b/llvm/test/Transforms/SCCP/sub-nuw-nsw-flags.ll
@@ -0,0 +1,51 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -passes=ipsccp -S %s | FileCheck %s
+
+define i8 @range_from_lshr(i8 %a) {
+; CHECK-LABEL: @range_from_lshr(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[A_SHR:%.*]] = lshr i8 [[A:%.*]], 1
+; CHECK-NEXT: [[SUB_1:%.*]] = sub i8 [[A_SHR]], 1
+; CHECK-NEXT: [[SUB_2:%.*]] = sub i8 [[A_SHR]], -128
+; CHECK-NEXT: [[SUB_3:%.*]] = sub i8 [[A_SHR]], -127
+; CHECK-NEXT: [[SUB_4:%.*]] = sub i8 [[A_SHR]], -1
+; CHECK-NEXT: [[RES_1:%.*]] = xor i8 [[SUB_1]], [[SUB_2]]
+; CHECK-NEXT: [[RES_2:%.*]] = xor i8 [[RES_1]], [[SUB_3]]
+; CHECK-NEXT: [[RES_3:%.*]] = xor i8 [[RES_2]], [[SUB_4]]
+; CHECK-NEXT: ret i8 [[RES_3]]
+;
+entry:
+ %a.shr = lshr i8 %a, 1
+ %sub.1 = sub i8 %a.shr, 1
+ %sub.2 = sub i8 %a.shr, 128
+ %sub.3 = sub i8 %a.shr, 129
+ %sub.4 = sub i8 %a.shr, -1
+ %res.1 = xor i8 %sub.1, %sub.2
+ %res.2 = xor i8 %res.1, %sub.3
+ %res.3 = xor i8 %res.2, %sub.4
+ ret i8 %res.3
+}
+
+
+define i8 @sub_zero(i8 %a) {
+; CHECK-LABEL: @sub_zero(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[SUB_1:%.*]] = sub i8 0, [[A:%.*]]
+; CHECK-NEXT: [[SUB_2:%.*]] = sub i8 -1, [[A]]
+; CHECK-NEXT: [[SUB_3:%.*]] = sub i8 1, [[A]]
+; CHECK-NEXT: [[SUB_4:%.*]] = sub i8 [[A]], -1
+; CHECK-NEXT: [[RES_1:%.*]] = xor i8 [[SUB_1]], [[SUB_2]]
+; CHECK-NEXT: [[RES_2:%.*]] = xor i8 [[RES_1]], [[SUB_3]]
+; CHECK-NEXT: [[RES_3:%.*]] = xor i8 [[RES_2]], [[SUB_4]]
+; CHECK-NEXT: ret i8 [[RES_3]]
+;
+entry:
+ %sub.1 = sub i8 0, %a
+ %sub.2 = sub i8 -1, %a
+ %sub.3 = sub i8 1, %a
+ %sub.4 = sub i8 %a, -1
+ %res.1 = xor i8 %sub.1, %sub.2
+ %res.2 = xor i8 %res.1, %sub.3
+ %res.3 = xor i8 %res.2, %sub.4
+ ret i8 %res.3
+}
More information about the llvm-commits
mailing list