From a67ad7b80e8347d4769d75669bf55d9ab3eee62c Mon Sep 17 00:00:00 2001 From: Alexey Bataev Date: Tue, 29 Aug 2017 14:37:23 +0000 Subject: [PATCH] [SimplifyCFG] Update initial test for better testing of the fix for PR34219, NFC. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@312002 91177308-0d34-0410-b5e6-96231b3b80d8 --- .../SimplifyCFG/preserve-store-alignment.ll | 212 +++++++++++++++++- 1 file changed, 210 insertions(+), 2 deletions(-) diff --git a/test/Transforms/SimplifyCFG/preserve-store-alignment.ll b/test/Transforms/SimplifyCFG/preserve-store-alignment.ll index 34c982010ec..8f7fcff0df2 100644 --- a/test/Transforms/SimplifyCFG/preserve-store-alignment.ll +++ b/test/Transforms/SimplifyCFG/preserve-store-alignment.ll @@ -6,8 +6,8 @@ @m = global i64 3, align 8 @counters = global %struct.Counters zeroinitializer, align 16 -define i32 @main() local_unnamed_addr { -; CHECK-LABEL: @main( +define i32 @align_both_equal() local_unnamed_addr { +; CHECK-LABEL: @align_both_equal( ; CHECK-NEXT: entry: ; CHECK-NEXT: [[TMP0:%.*]] = load <2 x i64>, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 ; CHECK-NEXT: [[TMP1:%.*]] = add nsw <2 x i64> [[TMP0]], @@ -57,3 +57,211 @@ if.then6: ; preds = %if.end if.end9: ; preds = %if.end, %if.then6 ret i32 0 } + +define i32 @align_not_equal() local_unnamed_addr { +; CHECK-LABEL: @align_not_equal( +; CHECK-NEXT: entry: +; CHECK-NEXT: [[TMP0:%.*]] = load <2 x i64>, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 +; CHECK-NEXT: [[TMP1:%.*]] = add nsw <2 x i64> [[TMP0]], +; CHECK-NEXT: store <2 x i64> [[TMP1]], <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 +; CHECK-NEXT: [[TMP2:%.*]] = load i64, i64* @m, align 8 +; CHECK-NEXT: [[AND:%.*]] = and i64 [[TMP2]], 1 +; CHECK-NEXT: [[TOBOOL:%.*]] = icmp eq i64 [[AND]], 0 +; CHECK-NEXT: [[TMP3:%.*]] = add nsw <2 x i64> [[TMP0]], +; CHECK-NEXT: [[TMP4:%.*]] = select i1 [[TOBOOL]], <2 x i64> [[TMP1]], <2 x i64> [[TMP3]] +; CHECK-NEXT: [[AND4:%.*]] = and i64 [[TMP2]], 2 +; CHECK-NEXT: [[TOBOOL5:%.*]] = icmp eq i64 [[AND4]], 0 +; CHECK-NEXT: [[TMP5:%.*]] = add nsw <2 x i64> [[TMP4]], +; CHECK-NEXT: [[DOT:%.*]] = select i1 [[TOBOOL5]], <2 x i64> [[TMP4]], <2 x i64> [[TMP5]] +; CHECK-NEXT: [[TMP6:%.*]] = xor i1 [[TOBOOL]], true +; CHECK-NEXT: [[TMP7:%.*]] = xor i1 [[TOBOOL5]], true +; CHECK-NEXT: [[TMP8:%.*]] = or i1 [[TMP6]], [[TMP7]] +; CHECK-NEXT: br i1 [[TMP8]], label [[TMP9:%.*]], label [[TMP10:%.*]] +; CHECK: store <2 x i64> [[DOT]], <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*) +; CHECK-NEXT: br label [[TMP10]] +; CHECK: ret i32 0 +; +entry: + %0 = load <2 x i64>, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + %1 = add nsw <2 x i64> %0, + store <2 x i64> %1, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + %2 = load i64, i64* @m, align 8 + %and = and i64 %2, 1 + %tobool = icmp eq i64 %and, 0 + br i1 %tobool, label %if.end, label %if.then + +if.then: ; preds = %entry + %3 = add nsw <2 x i64> %0, + store <2 x i64> %3, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 16 + br label %if.end + +if.end: ; preds = %entry, %if.then + %4 = phi <2 x i64> [ %1, %entry ], [ %3, %if.then ] + %and4 = and i64 %2, 2 + %tobool5 = icmp eq i64 %and4, 0 + br i1 %tobool5, label %if.end9, label %if.then6 + +if.then6: ; preds = %if.end + %5 = add nsw <2 x i64> %4, + store <2 x i64> %5, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + br label %if.end9 + +if.end9: ; preds = %if.end, %if.then6 + ret i32 0 +} + +define i32 @align_single_zero() local_unnamed_addr { +; CHECK-LABEL: @align_single_zero( +; CHECK-NEXT: entry: +; CHECK-NEXT: [[TMP0:%.*]] = load <2 x i64>, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 +; CHECK-NEXT: [[TMP1:%.*]] = add nsw <2 x i64> [[TMP0]], +; CHECK-NEXT: store <2 x i64> [[TMP1]], <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 +; CHECK-NEXT: [[TMP2:%.*]] = load i64, i64* @m, align 8 +; CHECK-NEXT: [[AND:%.*]] = and i64 [[TMP2]], 1 +; CHECK-NEXT: [[TOBOOL:%.*]] = icmp eq i64 [[AND]], 0 +; CHECK-NEXT: [[TMP3:%.*]] = add nsw <2 x i64> [[TMP0]], +; CHECK-NEXT: [[TMP4:%.*]] = select i1 [[TOBOOL]], <2 x i64> [[TMP1]], <2 x i64> [[TMP3]] +; CHECK-NEXT: [[AND4:%.*]] = and i64 [[TMP2]], 2 +; CHECK-NEXT: [[TOBOOL5:%.*]] = icmp eq i64 [[AND4]], 0 +; CHECK-NEXT: [[TMP5:%.*]] = add nsw <2 x i64> [[TMP4]], +; CHECK-NEXT: [[DOT:%.*]] = select i1 [[TOBOOL5]], <2 x i64> [[TMP4]], <2 x i64> [[TMP5]] +; CHECK-NEXT: [[TMP6:%.*]] = xor i1 [[TOBOOL]], true +; CHECK-NEXT: [[TMP7:%.*]] = xor i1 [[TOBOOL5]], true +; CHECK-NEXT: [[TMP8:%.*]] = or i1 [[TMP6]], [[TMP7]] +; CHECK-NEXT: br i1 [[TMP8]], label [[TMP9:%.*]], label [[TMP10:%.*]] +; CHECK: store <2 x i64> [[DOT]], <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*) +; CHECK-NEXT: br label [[TMP10]] +; CHECK: ret i32 0 +; +entry: + %0 = load <2 x i64>, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + %1 = add nsw <2 x i64> %0, + store <2 x i64> %1, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + %2 = load i64, i64* @m, align 8 + %and = and i64 %2, 1 + %tobool = icmp eq i64 %and, 0 + br i1 %tobool, label %if.end, label %if.then + +if.then: ; preds = %entry + %3 = add nsw <2 x i64> %0, + store <2 x i64> %3, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*) + br label %if.end + +if.end: ; preds = %entry, %if.then + %4 = phi <2 x i64> [ %1, %entry ], [ %3, %if.then ] + %and4 = and i64 %2, 2 + %tobool5 = icmp eq i64 %and4, 0 + br i1 %tobool5, label %if.end9, label %if.then6 + +if.then6: ; preds = %if.end + %5 = add nsw <2 x i64> %4, + store <2 x i64> %5, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + br label %if.end9 + +if.end9: ; preds = %if.end, %if.then6 + ret i32 0 +} + +define i32 @align_single_zero_second_greater_default() local_unnamed_addr { +; CHECK-LABEL: @align_single_zero_second_greater_default( +; CHECK-NEXT: entry: +; CHECK-NEXT: [[TMP0:%.*]] = load <2 x i64>, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 +; CHECK-NEXT: [[TMP1:%.*]] = add nsw <2 x i64> [[TMP0]], +; CHECK-NEXT: store <2 x i64> [[TMP1]], <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 +; CHECK-NEXT: [[TMP2:%.*]] = load i64, i64* @m, align 8 +; CHECK-NEXT: [[AND:%.*]] = and i64 [[TMP2]], 1 +; CHECK-NEXT: [[TOBOOL:%.*]] = icmp eq i64 [[AND]], 0 +; CHECK-NEXT: [[TMP3:%.*]] = add nsw <2 x i64> [[TMP0]], +; CHECK-NEXT: [[TMP4:%.*]] = select i1 [[TOBOOL]], <2 x i64> [[TMP1]], <2 x i64> [[TMP3]] +; CHECK-NEXT: [[AND4:%.*]] = and i64 [[TMP2]], 2 +; CHECK-NEXT: [[TOBOOL5:%.*]] = icmp eq i64 [[AND4]], 0 +; CHECK-NEXT: [[TMP5:%.*]] = add nsw <2 x i64> [[TMP4]], +; CHECK-NEXT: [[DOT:%.*]] = select i1 [[TOBOOL5]], <2 x i64> [[TMP4]], <2 x i64> [[TMP5]] +; CHECK-NEXT: [[TMP6:%.*]] = xor i1 [[TOBOOL]], true +; CHECK-NEXT: [[TMP7:%.*]] = xor i1 [[TOBOOL5]], true +; CHECK-NEXT: [[TMP8:%.*]] = or i1 [[TMP6]], [[TMP7]] +; CHECK-NEXT: br i1 [[TMP8]], label [[TMP9:%.*]], label [[TMP10:%.*]] +; CHECK: store <2 x i64> [[DOT]], <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*) +; CHECK-NEXT: br label [[TMP10]] +; CHECK: ret i32 0 +; +entry: + %0 = load <2 x i64>, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + %1 = add nsw <2 x i64> %0, + store <2 x i64> %1, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + %2 = load i64, i64* @m, align 8 + %and = and i64 %2, 1 + %tobool = icmp eq i64 %and, 0 + br i1 %tobool, label %if.end, label %if.then + +if.then: ; preds = %entry + %3 = add nsw <2 x i64> %0, + store <2 x i64> %3, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 32 + br label %if.end + +if.end: ; preds = %entry, %if.then + %4 = phi <2 x i64> [ %1, %entry ], [ %3, %if.then ] + %and4 = and i64 %2, 2 + %tobool5 = icmp eq i64 %and4, 0 + br i1 %tobool5, label %if.end9, label %if.then6 + +if.then6: ; preds = %if.end + %5 = add nsw <2 x i64> %4, + store <2 x i64> %5, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*) + br label %if.end9 + +if.end9: ; preds = %if.end, %if.then6 + ret i32 0 +} + +define i32 @align_both_zero() local_unnamed_addr { +; CHECK-LABEL: @align_both_zero( +; CHECK-NEXT: entry: +; CHECK-NEXT: [[TMP0:%.*]] = load <2 x i64>, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 +; CHECK-NEXT: [[TMP1:%.*]] = add nsw <2 x i64> [[TMP0]], +; CHECK-NEXT: store <2 x i64> [[TMP1]], <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 +; CHECK-NEXT: [[TMP2:%.*]] = load i64, i64* @m, align 8 +; CHECK-NEXT: [[AND:%.*]] = and i64 [[TMP2]], 1 +; CHECK-NEXT: [[TOBOOL:%.*]] = icmp eq i64 [[AND]], 0 +; CHECK-NEXT: [[TMP3:%.*]] = add nsw <2 x i64> [[TMP0]], +; CHECK-NEXT: [[TMP4:%.*]] = select i1 [[TOBOOL]], <2 x i64> [[TMP1]], <2 x i64> [[TMP3]] +; CHECK-NEXT: [[AND4:%.*]] = and i64 [[TMP2]], 2 +; CHECK-NEXT: [[TOBOOL5:%.*]] = icmp eq i64 [[AND4]], 0 +; CHECK-NEXT: [[TMP5:%.*]] = add nsw <2 x i64> [[TMP4]], +; CHECK-NEXT: [[DOT:%.*]] = select i1 [[TOBOOL5]], <2 x i64> [[TMP4]], <2 x i64> [[TMP5]] +; CHECK-NEXT: [[TMP6:%.*]] = xor i1 [[TOBOOL]], true +; CHECK-NEXT: [[TMP7:%.*]] = xor i1 [[TOBOOL5]], true +; CHECK-NEXT: [[TMP8:%.*]] = or i1 [[TMP6]], [[TMP7]] +; CHECK-NEXT: br i1 [[TMP8]], label [[TMP9:%.*]], label [[TMP10:%.*]] +; CHECK: store <2 x i64> [[DOT]], <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*) +; CHECK-NEXT: br label [[TMP10]] +; CHECK: ret i32 0 +; +entry: + %0 = load <2 x i64>, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + %1 = add nsw <2 x i64> %0, + store <2 x i64> %1, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*), align 8 + %2 = load i64, i64* @m, align 8 + %and = and i64 %2, 1 + %tobool = icmp eq i64 %and, 0 + br i1 %tobool, label %if.end, label %if.then + +if.then: ; preds = %entry + %3 = add nsw <2 x i64> %0, + store <2 x i64> %3, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*) + br label %if.end + +if.end: ; preds = %entry, %if.then + %4 = phi <2 x i64> [ %1, %entry ], [ %3, %if.then ] + %and4 = and i64 %2, 2 + %tobool5 = icmp eq i64 %and4, 0 + br i1 %tobool5, label %if.end9, label %if.then6 + +if.then6: ; preds = %if.end + %5 = add nsw <2 x i64> %4, + store <2 x i64> %5, <2 x i64>* bitcast (i64* getelementptr inbounds (%struct.Counters, %struct.Counters* @counters, i64 0, i32 1) to <2 x i64>*) + br label %if.end9 + +if.end9: ; preds = %if.end, %if.then6 + ret i32 0 +} -- 2.50.1