xref: /aosp_15_r20/external/llvm/test/Transforms/IndVarSimplify/eliminate-rem.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: opt -indvars -S < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker; Indvars should be able to eliminate this srem.
6*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @simple(
7*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: rem
8*9880d681SAndroid Build Coastguard Worker; CHECK: ret
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerdefine void @simple(i64 %arg, double* %arg3) nounwind {
11*9880d681SAndroid Build Coastguard Workerbb:
12*9880d681SAndroid Build Coastguard Worker  %t = icmp slt i64 0, %arg                     ; <i1> [#uses=1]
13*9880d681SAndroid Build Coastguard Worker  br i1 %t, label %bb4, label %bb12
14*9880d681SAndroid Build Coastguard Worker
15*9880d681SAndroid Build Coastguard Workerbb4:                                              ; preds = %bb
16*9880d681SAndroid Build Coastguard Worker  br label %bb5
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Workerbb5:                                              ; preds = %bb4, %bb5
19*9880d681SAndroid Build Coastguard Worker  %t6 = phi i64 [ %t9, %bb5 ], [ 0, %bb4 ]    ; <i64> [#uses=2]
20*9880d681SAndroid Build Coastguard Worker  %t7 = srem i64 %t6, %arg                    ; <i64> [#uses=1]
21*9880d681SAndroid Build Coastguard Worker  %t8 = getelementptr inbounds double, double* %arg3, i64 %t7 ; <double*> [#uses=1]
22*9880d681SAndroid Build Coastguard Worker  store double 0.000000e+00, double* %t8
23*9880d681SAndroid Build Coastguard Worker  %t9 = add nsw i64 %t6, 1                    ; <i64> [#uses=2]
24*9880d681SAndroid Build Coastguard Worker  %t10 = icmp slt i64 %t9, %arg               ; <i1> [#uses=1]
25*9880d681SAndroid Build Coastguard Worker  br i1 %t10, label %bb5, label %bb11
26*9880d681SAndroid Build Coastguard Worker
27*9880d681SAndroid Build Coastguard Workerbb11:                                             ; preds = %bb5
28*9880d681SAndroid Build Coastguard Worker  br label %bb12
29*9880d681SAndroid Build Coastguard Worker
30*9880d681SAndroid Build Coastguard Workerbb12:                                             ; preds = %bb11, %bb
31*9880d681SAndroid Build Coastguard Worker  ret void
32*9880d681SAndroid Build Coastguard Worker}
33*9880d681SAndroid Build Coastguard Worker
34*9880d681SAndroid Build Coastguard Worker; Indvars should be able to eliminate the (i+1)%n.
35*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @f(
36*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: rem
37*9880d681SAndroid Build Coastguard Worker; CHECK: rem
38*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: rem
39*9880d681SAndroid Build Coastguard Worker; CHECK: ret
40*9880d681SAndroid Build Coastguard Worker
41*9880d681SAndroid Build Coastguard Workerdefine i32 @f(i64* %arg, i64 %arg1, i64 %arg2, i64 %arg3) nounwind {
42*9880d681SAndroid Build Coastguard Workerbb:
43*9880d681SAndroid Build Coastguard Worker  %t = icmp sgt i64 %arg1, 0                      ; <i1> [#uses=1]
44*9880d681SAndroid Build Coastguard Worker  br i1 %t, label %bb4, label %bb54
45*9880d681SAndroid Build Coastguard Worker
46*9880d681SAndroid Build Coastguard Workerbb4:                                              ; preds = %bb
47*9880d681SAndroid Build Coastguard Worker  br label %bb5
48*9880d681SAndroid Build Coastguard Worker
49*9880d681SAndroid Build Coastguard Workerbb5:                                              ; preds = %bb49, %bb4
50*9880d681SAndroid Build Coastguard Worker  %t6 = phi i64 [ %t51, %bb49 ], [ 0, %bb4 ]      ; <i64> [#uses=4]
51*9880d681SAndroid Build Coastguard Worker  %t7 = phi i32 [ %t50, %bb49 ], [ 0, %bb4 ]      ; <i32> [#uses=2]
52*9880d681SAndroid Build Coastguard Worker  %t8 = add nsw i64 %t6, %arg1                    ; <i64> [#uses=1]
53*9880d681SAndroid Build Coastguard Worker  %t9 = add nsw i64 %t8, -2                       ; <i64> [#uses=1]
54*9880d681SAndroid Build Coastguard Worker  %t10 = srem i64 %t9, %arg1                      ; <i64> [#uses=1]
55*9880d681SAndroid Build Coastguard Worker  %t11 = add nsw i64 %t10, 1                      ; <i64> [#uses=1]
56*9880d681SAndroid Build Coastguard Worker  %t12 = add nsw i64 %t6, 1                       ; <i64> [#uses=1]
57*9880d681SAndroid Build Coastguard Worker  %t13 = srem i64 %t12, %arg1                     ; <i64> [#uses=1]
58*9880d681SAndroid Build Coastguard Worker  %t14 = icmp sgt i64 %arg1, 0                    ; <i1> [#uses=1]
59*9880d681SAndroid Build Coastguard Worker  br i1 %t14, label %bb15, label %bb49
60*9880d681SAndroid Build Coastguard Worker
61*9880d681SAndroid Build Coastguard Workerbb15:                                             ; preds = %bb5
62*9880d681SAndroid Build Coastguard Worker  br label %bb16
63*9880d681SAndroid Build Coastguard Worker
64*9880d681SAndroid Build Coastguard Workerbb16:                                             ; preds = %bb44, %bb15
65*9880d681SAndroid Build Coastguard Worker  %t17 = phi i64 [ %t46, %bb44 ], [ 0, %bb15 ]    ; <i64> [#uses=1]
66*9880d681SAndroid Build Coastguard Worker  %t18 = phi i32 [ %t45, %bb44 ], [ %t7, %bb15 ]  ; <i32> [#uses=2]
67*9880d681SAndroid Build Coastguard Worker  %t19 = icmp sgt i64 %arg1, 0                    ; <i1> [#uses=1]
68*9880d681SAndroid Build Coastguard Worker  br i1 %t19, label %bb20, label %bb44
69*9880d681SAndroid Build Coastguard Worker
70*9880d681SAndroid Build Coastguard Workerbb20:                                             ; preds = %bb16
71*9880d681SAndroid Build Coastguard Worker  br label %bb21
72*9880d681SAndroid Build Coastguard Worker
73*9880d681SAndroid Build Coastguard Workerbb21:                                             ; preds = %bb21, %bb20
74*9880d681SAndroid Build Coastguard Worker  %t22 = phi i64 [ %t41, %bb21 ], [ 0, %bb20 ]    ; <i64> [#uses=4]
75*9880d681SAndroid Build Coastguard Worker  %t23 = phi i32 [ %t40, %bb21 ], [ %t18, %bb20 ] ; <i32> [#uses=1]
76*9880d681SAndroid Build Coastguard Worker  %t24 = mul i64 %t6, %arg1                       ; <i64> [#uses=1]
77*9880d681SAndroid Build Coastguard Worker  %t25 = mul i64 %t13, %arg1                      ; <i64> [#uses=1]
78*9880d681SAndroid Build Coastguard Worker  %t26 = add nsw i64 %t24, %t22                   ; <i64> [#uses=1]
79*9880d681SAndroid Build Coastguard Worker  %t27 = mul i64 %t11, %arg1                      ; <i64> [#uses=1]
80*9880d681SAndroid Build Coastguard Worker  %t28 = add nsw i64 %t25, %t22                   ; <i64> [#uses=1]
81*9880d681SAndroid Build Coastguard Worker  %t29 = getelementptr inbounds i64, i64* %arg, i64 %t26 ; <i64*> [#uses=1]
82*9880d681SAndroid Build Coastguard Worker  %t30 = add nsw i64 %t27, %t22                   ; <i64> [#uses=1]
83*9880d681SAndroid Build Coastguard Worker  %t31 = getelementptr inbounds i64, i64* %arg, i64 %t28 ; <i64*> [#uses=1]
84*9880d681SAndroid Build Coastguard Worker  %t32 = zext i32 %t23 to i64                     ; <i64> [#uses=1]
85*9880d681SAndroid Build Coastguard Worker  %t33 = load i64, i64* %t29                           ; <i64> [#uses=1]
86*9880d681SAndroid Build Coastguard Worker  %t34 = getelementptr inbounds i64, i64* %arg, i64 %t30 ; <i64*> [#uses=1]
87*9880d681SAndroid Build Coastguard Worker  %t35 = load i64, i64* %t31                           ; <i64> [#uses=1]
88*9880d681SAndroid Build Coastguard Worker  %t36 = add nsw i64 %t32, %t33                   ; <i64> [#uses=1]
89*9880d681SAndroid Build Coastguard Worker  %t37 = add nsw i64 %t36, %t35                   ; <i64> [#uses=1]
90*9880d681SAndroid Build Coastguard Worker  %t38 = load i64, i64* %t34                           ; <i64> [#uses=1]
91*9880d681SAndroid Build Coastguard Worker  %t39 = add nsw i64 %t37, %t38                   ; <i64> [#uses=1]
92*9880d681SAndroid Build Coastguard Worker  %t40 = trunc i64 %t39 to i32                    ; <i32> [#uses=2]
93*9880d681SAndroid Build Coastguard Worker  %t41 = add nsw i64 %t22, 1                      ; <i64> [#uses=2]
94*9880d681SAndroid Build Coastguard Worker  %t42 = icmp slt i64 %t41, %arg1                 ; <i1> [#uses=1]
95*9880d681SAndroid Build Coastguard Worker  br i1 %t42, label %bb21, label %bb43
96*9880d681SAndroid Build Coastguard Worker
97*9880d681SAndroid Build Coastguard Workerbb43:                                             ; preds = %bb21
98*9880d681SAndroid Build Coastguard Worker  br label %bb44
99*9880d681SAndroid Build Coastguard Worker
100*9880d681SAndroid Build Coastguard Workerbb44:                                             ; preds = %bb43, %bb16
101*9880d681SAndroid Build Coastguard Worker  %t45 = phi i32 [ %t18, %bb16 ], [ %t40, %bb43 ] ; <i32> [#uses=2]
102*9880d681SAndroid Build Coastguard Worker  %t46 = add nsw i64 %t17, 1                      ; <i64> [#uses=2]
103*9880d681SAndroid Build Coastguard Worker  %t47 = icmp slt i64 %t46, %arg1                 ; <i1> [#uses=1]
104*9880d681SAndroid Build Coastguard Worker  br i1 %t47, label %bb16, label %bb48
105*9880d681SAndroid Build Coastguard Worker
106*9880d681SAndroid Build Coastguard Workerbb48:                                             ; preds = %bb44
107*9880d681SAndroid Build Coastguard Worker  br label %bb49
108*9880d681SAndroid Build Coastguard Worker
109*9880d681SAndroid Build Coastguard Workerbb49:                                             ; preds = %bb48, %bb5
110*9880d681SAndroid Build Coastguard Worker  %t50 = phi i32 [ %t7, %bb5 ], [ %t45, %bb48 ]   ; <i32> [#uses=2]
111*9880d681SAndroid Build Coastguard Worker  %t51 = add nsw i64 %t6, 1                       ; <i64> [#uses=2]
112*9880d681SAndroid Build Coastguard Worker  %t52 = icmp slt i64 %t51, %arg1                 ; <i1> [#uses=1]
113*9880d681SAndroid Build Coastguard Worker  br i1 %t52, label %bb5, label %bb53
114*9880d681SAndroid Build Coastguard Worker
115*9880d681SAndroid Build Coastguard Workerbb53:                                             ; preds = %bb49
116*9880d681SAndroid Build Coastguard Worker  br label %bb54
117*9880d681SAndroid Build Coastguard Worker
118*9880d681SAndroid Build Coastguard Workerbb54:                                             ; preds = %bb53, %bb
119*9880d681SAndroid Build Coastguard Worker  %t55 = phi i32 [ 0, %bb ], [ %t50, %bb53 ]      ; <i32> [#uses=1]
120*9880d681SAndroid Build Coastguard Worker  ret i32 %t55
121*9880d681SAndroid Build Coastguard Worker}
122