eliminate-rem.ll 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. ; RUN: opt -indvars -S < %s | FileCheck %s
  2. target 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"
  3. ; Indvars should be able to eliminate this srem.
  4. ; CHECK-LABEL: @simple(
  5. ; CHECK-NOT: rem
  6. ; CHECK: ret
  7. define void @simple(i64 %arg, double* %arg3) nounwind {
  8. bb:
  9. %t = icmp slt i64 0, %arg ; <i1> [#uses=1]
  10. br i1 %t, label %bb4, label %bb12
  11. bb4: ; preds = %bb
  12. br label %bb5
  13. bb5: ; preds = %bb4, %bb5
  14. %t6 = phi i64 [ %t9, %bb5 ], [ 0, %bb4 ] ; <i64> [#uses=2]
  15. %t7 = srem i64 %t6, %arg ; <i64> [#uses=1]
  16. %t8 = getelementptr inbounds double, double* %arg3, i64 %t7 ; <double*> [#uses=1]
  17. store double 0.000000e+00, double* %t8
  18. %t9 = add nsw i64 %t6, 1 ; <i64> [#uses=2]
  19. %t10 = icmp slt i64 %t9, %arg ; <i1> [#uses=1]
  20. br i1 %t10, label %bb5, label %bb11
  21. bb11: ; preds = %bb5
  22. br label %bb12
  23. bb12: ; preds = %bb11, %bb
  24. ret void
  25. }
  26. ; Indvars should be able to eliminate the (i+1)%n.
  27. ; CHECK-LABEL: @f(
  28. ; CHECK-NOT: rem
  29. ; CHECK: rem
  30. ; CHECK-NOT: rem
  31. ; CHECK: ret
  32. define i32 @f(i64* %arg, i64 %arg1, i64 %arg2, i64 %arg3) nounwind {
  33. bb:
  34. %t = icmp sgt i64 %arg1, 0 ; <i1> [#uses=1]
  35. br i1 %t, label %bb4, label %bb54
  36. bb4: ; preds = %bb
  37. br label %bb5
  38. bb5: ; preds = %bb49, %bb4
  39. %t6 = phi i64 [ %t51, %bb49 ], [ 0, %bb4 ] ; <i64> [#uses=4]
  40. %t7 = phi i32 [ %t50, %bb49 ], [ 0, %bb4 ] ; <i32> [#uses=2]
  41. %t8 = add nsw i64 %t6, %arg1 ; <i64> [#uses=1]
  42. %t9 = add nsw i64 %t8, -2 ; <i64> [#uses=1]
  43. %t10 = srem i64 %t9, %arg1 ; <i64> [#uses=1]
  44. %t11 = add nsw i64 %t10, 1 ; <i64> [#uses=1]
  45. %t12 = add nsw i64 %t6, 1 ; <i64> [#uses=1]
  46. %t13 = srem i64 %t12, %arg1 ; <i64> [#uses=1]
  47. %t14 = icmp sgt i64 %arg1, 0 ; <i1> [#uses=1]
  48. br i1 %t14, label %bb15, label %bb49
  49. bb15: ; preds = %bb5
  50. br label %bb16
  51. bb16: ; preds = %bb44, %bb15
  52. %t17 = phi i64 [ %t46, %bb44 ], [ 0, %bb15 ] ; <i64> [#uses=1]
  53. %t18 = phi i32 [ %t45, %bb44 ], [ %t7, %bb15 ] ; <i32> [#uses=2]
  54. %t19 = icmp sgt i64 %arg1, 0 ; <i1> [#uses=1]
  55. br i1 %t19, label %bb20, label %bb44
  56. bb20: ; preds = %bb16
  57. br label %bb21
  58. bb21: ; preds = %bb21, %bb20
  59. %t22 = phi i64 [ %t41, %bb21 ], [ 0, %bb20 ] ; <i64> [#uses=4]
  60. %t23 = phi i32 [ %t40, %bb21 ], [ %t18, %bb20 ] ; <i32> [#uses=1]
  61. %t24 = mul i64 %t6, %arg1 ; <i64> [#uses=1]
  62. %t25 = mul i64 %t13, %arg1 ; <i64> [#uses=1]
  63. %t26 = add nsw i64 %t24, %t22 ; <i64> [#uses=1]
  64. %t27 = mul i64 %t11, %arg1 ; <i64> [#uses=1]
  65. %t28 = add nsw i64 %t25, %t22 ; <i64> [#uses=1]
  66. %t29 = getelementptr inbounds i64, i64* %arg, i64 %t26 ; <i64*> [#uses=1]
  67. %t30 = add nsw i64 %t27, %t22 ; <i64> [#uses=1]
  68. %t31 = getelementptr inbounds i64, i64* %arg, i64 %t28 ; <i64*> [#uses=1]
  69. %t32 = zext i32 %t23 to i64 ; <i64> [#uses=1]
  70. %t33 = load i64, i64* %t29 ; <i64> [#uses=1]
  71. %t34 = getelementptr inbounds i64, i64* %arg, i64 %t30 ; <i64*> [#uses=1]
  72. %t35 = load i64, i64* %t31 ; <i64> [#uses=1]
  73. %t36 = add nsw i64 %t32, %t33 ; <i64> [#uses=1]
  74. %t37 = add nsw i64 %t36, %t35 ; <i64> [#uses=1]
  75. %t38 = load i64, i64* %t34 ; <i64> [#uses=1]
  76. %t39 = add nsw i64 %t37, %t38 ; <i64> [#uses=1]
  77. %t40 = trunc i64 %t39 to i32 ; <i32> [#uses=2]
  78. %t41 = add nsw i64 %t22, 1 ; <i64> [#uses=2]
  79. %t42 = icmp slt i64 %t41, %arg1 ; <i1> [#uses=1]
  80. br i1 %t42, label %bb21, label %bb43
  81. bb43: ; preds = %bb21
  82. br label %bb44
  83. bb44: ; preds = %bb43, %bb16
  84. %t45 = phi i32 [ %t18, %bb16 ], [ %t40, %bb43 ] ; <i32> [#uses=2]
  85. %t46 = add nsw i64 %t17, 1 ; <i64> [#uses=2]
  86. %t47 = icmp slt i64 %t46, %arg1 ; <i1> [#uses=1]
  87. br i1 %t47, label %bb16, label %bb48
  88. bb48: ; preds = %bb44
  89. br label %bb49
  90. bb49: ; preds = %bb48, %bb5
  91. %t50 = phi i32 [ %t7, %bb5 ], [ %t45, %bb48 ] ; <i32> [#uses=2]
  92. %t51 = add nsw i64 %t6, 1 ; <i64> [#uses=2]
  93. %t52 = icmp slt i64 %t51, %arg1 ; <i1> [#uses=1]
  94. br i1 %t52, label %bb5, label %bb53
  95. bb53: ; preds = %bb49
  96. br label %bb54
  97. bb54: ; preds = %bb53, %bb
  98. %t55 = phi i32 [ 0, %bb ], [ %t50, %bb53 ] ; <i32> [#uses=1]
  99. ret i32 %t55
  100. }