The legacy PM is deprecated, so update a bunch of lit tests running opt to use the new PM syntax when specifying the pipeline. In this patch focus has been put on test cases for ConstantMerge, ConstraintElimination, CorrelatedValuePropagation, GlobalDCE, GlobalOpt, SCCP, TailCallElim and PredicateInfo. Differential Revision: https://reviews.llvm.org/D114516
94 lines
4.0 KiB
LLVM
94 lines
4.0 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
|
; RUN: opt -passes=print-predicateinfo < %s 2>&1 | FileCheck %s
|
|
; Don't insert predicate info for conditions with a single target.
|
|
@a = global i32 6, align 4
|
|
@c = global i32 -1, align 4
|
|
@e = common global i32 0, align 4
|
|
@.str = private unnamed_addr constant [4 x i8] c"%d\0A\00", align 1
|
|
@d = common global i32 0, align 4
|
|
@b = common global [6 x i32] zeroinitializer, align 16
|
|
|
|
; Function Attrs: nounwind ssp uwtable
|
|
define i32 @main() {
|
|
; CHECK-LABEL: @main(
|
|
; CHECK-NEXT: store i32 6, i32* @e, align 4
|
|
; CHECK-NEXT: br label [[TMP1:%.*]]
|
|
; CHECK: [[TMP2:%.*]] = load i32, i32* @d, align 4
|
|
; CHECK-NEXT: [[TMP3:%.*]] = sext i32 [[TMP2]] to i64
|
|
; CHECK-NEXT: [[TMP4:%.*]] = getelementptr inbounds [6 x i32], [6 x i32]* @b, i64 0, i64 [[TMP3]]
|
|
; CHECK-NEXT: [[TMP5:%.*]] = load i32, i32* [[TMP4]], align 4
|
|
; CHECK-NEXT: [[TMP6:%.*]] = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i64 0, i64 0), i32 [[TMP5]])
|
|
; CHECK-NEXT: [[TMP7:%.*]] = load i32, i32* @a, align 4
|
|
; CHECK-NEXT: [[TMP8:%.*]] = icmp eq i32 [[TMP7]], 0
|
|
; CHECK-NEXT: br i1 [[TMP8]], label %thread-pre-split, label [[TMP9:%.*]]
|
|
; CHECK: [[TMP10:%.*]] = load i32, i32* @e, align 4
|
|
; CHECK-NEXT: [[TMP11:%.*]] = icmp eq i32 [[TMP10]], 0
|
|
; CHECK-NEXT: br i1 [[TMP11]], label [[TMP12:%.*]], label [[TMP12]]
|
|
; CHECK: thread-pre-split:
|
|
; CHECK-NEXT: [[DOTPR:%.*]] = load i32, i32* @e, align 4
|
|
; CHECK-NEXT: br label [[TMP12]]
|
|
; CHECK: [[TMP13:%.*]] = phi i32 [ [[DOTPR]], %thread-pre-split ], [ [[TMP10]], [[TMP9]] ], [ [[TMP10]], [[TMP9]] ]
|
|
; CHECK-NEXT: [[TMP14:%.*]] = icmp ne i32 [[TMP13]], 0
|
|
; CHECK-NEXT: br i1 [[TMP14]], label [[TMP15:%.*]], label [[TMP15]]
|
|
; CHECK: br i1 [[TMP14]], label [[TMP16:%.*]], label [[TMP17:%.*]]
|
|
; CHECK: br label [[TMP17]]
|
|
; CHECK: [[DOT0:%.*]] = phi i32 [ 1, [[TMP16]] ], [ -1, [[TMP15]] ]
|
|
; CHECK-NEXT: [[TMP18:%.*]] = and i32 [[DOT0]], 8693
|
|
; CHECK-NEXT: [[TMP19:%.*]] = load i32, i32* @c, align 4
|
|
; CHECK-NEXT: [[TMP20:%.*]] = xor i32 [[TMP18]], [[TMP19]]
|
|
; CHECK-NEXT: [[TMP21:%.*]] = xor i32 [[TMP20]], -1
|
|
; CHECK-NEXT: store i32 [[TMP21]], i32* @d, align 4
|
|
; CHECK-NEXT: [[TMP22:%.*]] = icmp slt i32 [[TMP20]], -2
|
|
; CHECK-NEXT: br i1 [[TMP22]], label [[TMP1]], label [[TMP23:%.*]]
|
|
; CHECK: ret i32 0
|
|
;
|
|
store i32 6, i32* @e, align 4
|
|
br label %1
|
|
|
|
; <label>:1: ; preds = %17, %0
|
|
%2 = load i32, i32* @d, align 4
|
|
%3 = sext i32 %2 to i64
|
|
%4 = getelementptr inbounds [6 x i32], [6 x i32]* @b, i64 0, i64 %3
|
|
%5 = load i32, i32* %4, align 4
|
|
%6 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i64 0, i64 0), i32 %5) #2
|
|
%7 = load i32, i32* @a, align 4
|
|
%8 = icmp eq i32 %7, 0
|
|
br i1 %8, label %thread-pre-split, label %9
|
|
|
|
; <label>:9: ; preds = %1
|
|
%10 = load i32, i32* @e, align 4
|
|
%11 = icmp eq i32 %10, 0
|
|
br i1 %11, label %12, label %12
|
|
|
|
thread-pre-split: ; preds = %1
|
|
%.pr = load i32, i32* @e, align 4
|
|
br label %12
|
|
|
|
; <label>:12: ; preds = %thread-pre-split, %9, %9
|
|
%13 = phi i32 [ %.pr, %thread-pre-split ], [ %10, %9 ], [ %10, %9 ]
|
|
%14 = icmp ne i32 %13, 0
|
|
br i1 %14, label %15, label %15
|
|
|
|
; <label>:15: ; preds = %12, %12
|
|
br i1 %14, label %16, label %17
|
|
|
|
; <label>:16: ; preds = %15
|
|
br label %17
|
|
|
|
; <label>:17: ; preds = %16, %15
|
|
%.0 = phi i32 [ 1, %16 ], [ -1, %15 ]
|
|
%18 = and i32 %.0, 8693
|
|
%19 = load i32, i32* @c, align 4
|
|
%20 = xor i32 %18, %19
|
|
%21 = xor i32 %20, -1
|
|
store i32 %21, i32* @d, align 4
|
|
%22 = icmp slt i32 %20, -2
|
|
br i1 %22, label %1, label %23
|
|
|
|
; <label>:23: ; preds = %17
|
|
ret i32 0
|
|
}
|
|
|
|
declare i32 @printf(i8*, ...)
|
|
|