llvm-for-llvmta/test/Analysis/IVUsers/deep_recursion_in_scev.ll

182 lines
7.4 KiB
LLVM
Raw Permalink Normal View History

2022-04-25 10:02:23 +02:00
; RUN: opt < %s -iv-users
; This is a regression test against very slow execution...
; In bad case it should fail by timeout.
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128-ni:1"
target triple = "x86_64-unknown-linux-gnu"
define void @quux(i8 addrspace(1)* %arg, i8 addrspace(1)* %arg1) {
bb:
%tmp2 = getelementptr inbounds i8, i8 addrspace(1)* %arg, i64 80
%tmp3 = bitcast i8 addrspace(1)* %tmp2 to i8 addrspace(1)* addrspace(1)*
%tmp4 = load i8 addrspace(1)*, i8 addrspace(1)* addrspace(1)* %tmp3, align 8
%tmp5 = getelementptr inbounds i8, i8 addrspace(1)* %tmp4, i64 8
%tmp6 = bitcast i8 addrspace(1)* %tmp5 to i8 addrspace(1)* addrspace(1)*
%tmp7 = load i8 addrspace(1)*, i8 addrspace(1)* addrspace(1)* %tmp6, align 8
%tmp8 = getelementptr inbounds i8, i8 addrspace(1)* %tmp7, i64 8
%tmp9 = bitcast i8 addrspace(1)* %tmp8 to i32 addrspace(1)*
%tmp10 = load i32, i32 addrspace(1)* %tmp9, align 8
%tmp11 = udiv i32 65, %tmp10
%tmp12 = getelementptr inbounds i8, i8 addrspace(1)* %arg, i64 80
%tmp13 = bitcast i8 addrspace(1)* %tmp12 to i8 addrspace(1)* addrspace(1)*
%tmp14 = load i8 addrspace(1)*, i8 addrspace(1)* addrspace(1)* %tmp13, align 8
%tmp15 = getelementptr inbounds i8, i8 addrspace(1)* %tmp14, i64 8
%tmp16 = bitcast i8 addrspace(1)* %tmp15 to i8 addrspace(1)* addrspace(1)*
%tmp17 = load i8 addrspace(1)*, i8 addrspace(1)* addrspace(1)* %tmp16, align 8
%tmp18 = getelementptr inbounds i8, i8 addrspace(1)* %arg1, i64 8
%tmp19 = bitcast i8 addrspace(1)* %tmp18 to i32 addrspace(1)*
%tmp20 = load i32, i32 addrspace(1)* %tmp19, align 8, !range !0
%tmp21 = getelementptr inbounds i8, i8 addrspace(1)* %tmp17, i64 8
%tmp22 = bitcast i8 addrspace(1)* %tmp21 to i32 addrspace(1)*
%tmp23 = load i32, i32 addrspace(1)* %tmp22, align 8, !range !0
%tmp24 = zext i32 %tmp23 to i64
%tmp25 = and i32 %tmp11, 7
%tmp26 = icmp ugt i32 %tmp10, 9
br i1 %tmp26, label %bb27, label %bb46
bb27: ; preds = %bb117, %bb
%tmp28 = phi i32 [ 8, %bb ], [ %tmp112, %bb117 ]
br label %bb29
bb29: ; preds = %bb40, %bb27
%tmp30 = phi i32 [ %tmp43, %bb40 ], [ %tmp28, %bb27 ]
%tmp31 = phi i32 [ %tmp41, %bb40 ], [ %tmp25, %bb27 ]
br label %bb32
bb32: ; preds = %bb37, %bb29
%tmp33 = phi i64 [ 0, %bb29 ], [ %tmp38, %bb37 ]
%tmp34 = trunc i64 %tmp33 to i32
%tmp35 = add i32 %tmp30, %tmp34
%tmp36 = icmp ult i32 %tmp35, %tmp20
br i1 %tmp36, label %bb37, label %bb56
bb37: ; preds = %bb32
%tmp38 = add nuw nsw i64 %tmp33, 1
%tmp39 = icmp ult i64 %tmp38, %tmp24
br i1 %tmp39, label %bb32, label %bb40
bb40: ; preds = %bb37
%tmp41 = add i32 %tmp31, -1
%tmp42 = trunc i64 %tmp38 to i32
%tmp43 = add i32 %tmp30, %tmp42
%tmp44 = icmp eq i32 %tmp41, 0
br i1 %tmp44, label %bb45, label %bb29
bb45: ; preds = %bb40
ret void
bb46: ; preds = %bb
%tmp47 = sub nsw i32 %tmp11, %tmp25
br label %bb48
bb48: ; preds = %bb117, %bb46
%tmp49 = phi i32 [ 8, %bb46 ], [ %tmp112, %bb117 ]
%tmp50 = phi i32 [ %tmp47, %bb46 ], [ %tmp118, %bb117 ]
br label %bb51
bb51: ; preds = %bb58, %bb48
%tmp52 = phi i64 [ 0, %bb48 ], [ %tmp59, %bb58 ]
%tmp53 = phi i32 [ %tmp49, %bb48 ], [ %tmp54, %bb58 ]
%tmp54 = add i32 %tmp53, 1
%tmp55 = icmp ult i32 %tmp53, %tmp20
br i1 %tmp55, label %bb58, label %bb56
bb56: ; preds = %bb109, %bb101, %bb93, %bb85, %bb77, %bb69, %bb61, %bb51, %bb32
unreachable
bb58: ; preds = %bb51
%tmp59 = add nuw nsw i64 %tmp52, 1
%tmp60 = icmp ult i64 %tmp59, %tmp24
br i1 %tmp60, label %bb51, label %bb61
bb61: ; preds = %bb66, %bb58
%tmp62 = phi i64 [ %tmp67, %bb66 ], [ 0, %bb58 ]
%tmp63 = phi i32 [ %tmp64, %bb66 ], [ %tmp54, %bb58 ]
%tmp64 = add i32 %tmp63, 1
%tmp65 = icmp ult i32 %tmp63, %tmp20
br i1 %tmp65, label %bb66, label %bb56
bb66: ; preds = %bb61
%tmp67 = add nuw nsw i64 %tmp62, 1
%tmp68 = icmp ult i64 %tmp67, %tmp24
br i1 %tmp68, label %bb61, label %bb69
bb69: ; preds = %bb74, %bb66
%tmp70 = phi i64 [ %tmp75, %bb74 ], [ 0, %bb66 ]
%tmp71 = phi i32 [ %tmp72, %bb74 ], [ %tmp64, %bb66 ]
%tmp72 = add i32 %tmp71, 1
%tmp73 = icmp ult i32 %tmp71, %tmp20
br i1 %tmp73, label %bb74, label %bb56
bb74: ; preds = %bb69
%tmp75 = add nuw nsw i64 %tmp70, 1
%tmp76 = icmp ult i64 %tmp75, %tmp24
br i1 %tmp76, label %bb69, label %bb77
bb77: ; preds = %bb82, %bb74
%tmp78 = phi i64 [ %tmp83, %bb82 ], [ 0, %bb74 ]
%tmp79 = phi i32 [ %tmp80, %bb82 ], [ %tmp72, %bb74 ]
%tmp80 = add i32 %tmp79, 1
%tmp81 = icmp ult i32 %tmp79, %tmp20
br i1 %tmp81, label %bb82, label %bb56
bb82: ; preds = %bb77
%tmp83 = add nuw nsw i64 %tmp78, 1
%tmp84 = icmp ult i64 %tmp83, %tmp24
br i1 %tmp84, label %bb77, label %bb85
bb85: ; preds = %bb90, %bb82
%tmp86 = phi i64 [ %tmp91, %bb90 ], [ 0, %bb82 ]
%tmp87 = phi i32 [ %tmp88, %bb90 ], [ %tmp80, %bb82 ]
%tmp88 = add i32 %tmp87, 1
%tmp89 = icmp ult i32 %tmp87, %tmp20
br i1 %tmp89, label %bb90, label %bb56
bb90: ; preds = %bb85
%tmp91 = add nuw nsw i64 %tmp86, 1
%tmp92 = icmp ult i64 %tmp91, %tmp24
br i1 %tmp92, label %bb85, label %bb93
bb93: ; preds = %bb98, %bb90
%tmp94 = phi i64 [ %tmp99, %bb98 ], [ 0, %bb90 ]
%tmp95 = phi i32 [ %tmp96, %bb98 ], [ %tmp88, %bb90 ]
%tmp96 = add i32 %tmp95, 1
%tmp97 = icmp ult i32 %tmp95, %tmp20
br i1 %tmp97, label %bb98, label %bb56
bb98: ; preds = %bb93
%tmp99 = add nuw nsw i64 %tmp94, 1
%tmp100 = icmp ult i64 %tmp99, %tmp24
br i1 %tmp100, label %bb93, label %bb101
bb101: ; preds = %bb106, %bb98
%tmp102 = phi i64 [ %tmp107, %bb106 ], [ 0, %bb98 ]
%tmp103 = phi i32 [ %tmp104, %bb106 ], [ %tmp96, %bb98 ]
%tmp104 = add i32 %tmp103, 1
%tmp105 = icmp ult i32 %tmp103, %tmp20
br i1 %tmp105, label %bb106, label %bb56
bb106: ; preds = %bb101
%tmp107 = add nuw nsw i64 %tmp102, 1
%tmp108 = icmp ult i64 %tmp107, %tmp24
br i1 %tmp108, label %bb101, label %bb109
bb109: ; preds = %bb114, %bb106
%tmp110 = phi i64 [ %tmp115, %bb114 ], [ 0, %bb106 ]
%tmp111 = phi i32 [ %tmp112, %bb114 ], [ %tmp104, %bb106 ]
%tmp112 = add i32 %tmp111, 1
%tmp113 = icmp ult i32 %tmp111, %tmp20
br i1 %tmp113, label %bb114, label %bb56
bb114: ; preds = %bb109
%tmp115 = add nuw nsw i64 %tmp110, 1
%tmp116 = icmp ult i64 %tmp115, %tmp24
br i1 %tmp116, label %bb109, label %bb117
bb117: ; preds = %bb114
%tmp118 = add i32 %tmp50, -8
%tmp119 = icmp eq i32 %tmp118, 0
br i1 %tmp119, label %bb27, label %bb48
}
!0 = !{i32 0, i32 2147483647}