llvm/llvm/test/Analysis/IVUsers/deep_recursion_in_scev.ll

; RUN: opt < %s -passes='print<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(ptr addrspace(1) %arg, ptr addrspace(1) %arg1) {
bb:
  %tmp2 = getelementptr inbounds i8, ptr addrspace(1) %arg, i64 80
  %tmp3 = bitcast ptr addrspace(1) %tmp2 to ptr addrspace(1)
  %tmp4 = load ptr addrspace(1), ptr addrspace(1) %tmp3, align 8
  %tmp5 = getelementptr inbounds i8, ptr addrspace(1) %tmp4, i64 8
  %tmp6 = bitcast ptr addrspace(1) %tmp5 to ptr addrspace(1)
  %tmp7 = load ptr addrspace(1), ptr addrspace(1) %tmp6, align 8
  %tmp8 = getelementptr inbounds i8, ptr addrspace(1) %tmp7, i64 8
  %tmp9 = bitcast ptr addrspace(1) %tmp8 to ptr addrspace(1)
  %tmp10 = load i32, ptr addrspace(1) %tmp9, align 8
  %tmp11 = udiv i32 65, %tmp10
  %tmp12 = getelementptr inbounds i8, ptr addrspace(1) %arg, i64 80
  %tmp13 = bitcast ptr addrspace(1) %tmp12 to ptr addrspace(1)
  %tmp14 = load ptr addrspace(1), ptr addrspace(1) %tmp13, align 8
  %tmp15 = getelementptr inbounds i8, ptr addrspace(1) %tmp14, i64 8
  %tmp16 = bitcast ptr addrspace(1) %tmp15 to ptr addrspace(1)
  %tmp17 = load ptr addrspace(1), ptr addrspace(1) %tmp16, align 8
  %tmp18 = getelementptr inbounds i8, ptr addrspace(1) %arg1, i64 8
  %tmp19 = bitcast ptr addrspace(1) %tmp18 to ptr addrspace(1)
  %tmp20 = load i32, ptr addrspace(1) %tmp19, align 8, !range !0
  %tmp21 = getelementptr inbounds i8, ptr addrspace(1) %tmp17, i64 8
  %tmp22 = bitcast ptr addrspace(1) %tmp21 to ptr addrspace(1)
  %tmp23 = load i32, ptr 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}