avoid-i0.ll 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. ; RUN: opt < %s -indvars
  2. ; PR4052
  3. ; PR4054
  4. ; Don't treat an and with 0 as a mask (trunc+zext).
  5. define i32 @int80(i8 signext %p_71) nounwind {
  6. entry:
  7. br label %bb
  8. bb: ; preds = %bb6, %entry
  9. %p_71_addr.0 = phi i8 [ %p_71, %entry ], [ %0, %bb6 ] ; <i8> [#uses=0]
  10. br i1 undef, label %bb4, label %bb1
  11. bb1: ; preds = %bb
  12. ret i32 0
  13. bb4: ; preds = %bb4, %bb
  14. br i1 undef, label %bb6, label %bb4
  15. bb6: ; preds = %bb4
  16. %0 = and i8 0, 0 ; <i8> [#uses=1]
  17. br label %bb
  18. }
  19. @x = common global i32 0 ; <i32*> [#uses=1]
  20. define signext i8 @safe_sub_func_int32_t_s_s(i32 %_si1, i8 signext %_si2) nounwind {
  21. entry:
  22. %_si1_addr = alloca i32 ; <i32*> [#uses=3]
  23. %_si2_addr = alloca i8 ; <i8*> [#uses=3]
  24. %retval = alloca i32 ; <i32*> [#uses=2]
  25. %0 = alloca i32 ; <i32*> [#uses=2]
  26. %"alloca point" = bitcast i32 0 to i32 ; <i32> [#uses=0]
  27. store i32 %_si1, i32* %_si1_addr
  28. store i8 %_si2, i8* %_si2_addr
  29. %1 = load i8, i8* %_si2_addr, align 1 ; <i8> [#uses=1]
  30. %2 = sext i8 %1 to i32 ; <i32> [#uses=1]
  31. %3 = load i32, i32* %_si1_addr, align 4 ; <i32> [#uses=1]
  32. %4 = xor i32 %2, %3 ; <i32> [#uses=1]
  33. %5 = load i8, i8* %_si2_addr, align 1 ; <i8> [#uses=1]
  34. %6 = sext i8 %5 to i32 ; <i32> [#uses=1]
  35. %7 = sub i32 7, %6 ; <i32> [#uses=1]
  36. %8 = load i32, i32* %_si1_addr, align 4 ; <i32> [#uses=1]
  37. %9 = shl i32 %8, %7 ; <i32> [#uses=1]
  38. %10 = and i32 %4, %9 ; <i32> [#uses=1]
  39. %11 = icmp slt i32 %10, 0 ; <i1> [#uses=1]
  40. %12 = zext i1 %11 to i32 ; <i32> [#uses=1]
  41. store i32 %12, i32* %0, align 4
  42. %13 = load i32, i32* %0, align 4 ; <i32> [#uses=1]
  43. store i32 %13, i32* %retval, align 4
  44. br label %return
  45. return: ; preds = %entry
  46. %retval1 = load i32, i32* %retval ; <i32> [#uses=1]
  47. %retval12 = trunc i32 %retval1 to i8 ; <i8> [#uses=1]
  48. ret i8 %retval12
  49. }
  50. define i32 @safe_sub_func_uint64_t_u_u(i32 %_ui1, i32 %_ui2) nounwind {
  51. entry:
  52. %_ui1_addr = alloca i32 ; <i32*> [#uses=2]
  53. %_ui2_addr = alloca i32 ; <i32*> [#uses=1]
  54. %retval = alloca i32 ; <i32*> [#uses=2]
  55. %0 = alloca i32 ; <i32*> [#uses=2]
  56. %"alloca point" = bitcast i32 0 to i32 ; <i32> [#uses=0]
  57. store i32 %_ui1, i32* %_ui1_addr
  58. store i32 %_ui2, i32* %_ui2_addr
  59. %1 = load i32, i32* %_ui1_addr, align 4 ; <i32> [#uses=1]
  60. %2 = sub i32 %1, 1 ; <i32> [#uses=1]
  61. store i32 %2, i32* %0, align 4
  62. %3 = load i32, i32* %0, align 4 ; <i32> [#uses=1]
  63. store i32 %3, i32* %retval, align 4
  64. br label %return
  65. return: ; preds = %entry
  66. %retval1 = load i32, i32* %retval ; <i32> [#uses=1]
  67. ret i32 %retval1
  68. }
  69. define void @int87(i8 signext %p_48, i8 signext %p_49) nounwind {
  70. entry:
  71. %p_48_addr = alloca i8 ; <i8*> [#uses=1]
  72. %p_49_addr = alloca i8 ; <i8*> [#uses=1]
  73. %l_52 = alloca i32 ; <i32*> [#uses=7]
  74. %vol.0 = alloca i32 ; <i32*> [#uses=1]
  75. %"alloca point" = bitcast i32 0 to i32 ; <i32> [#uses=0]
  76. store i8 %p_48, i8* %p_48_addr
  77. store i8 %p_49, i8* %p_49_addr
  78. br label %bb4
  79. bb: ; preds = %bb4
  80. %0 = load volatile i32, i32* @x, align 4 ; <i32> [#uses=1]
  81. store i32 %0, i32* %vol.0, align 4
  82. store i32 0, i32* %l_52, align 4
  83. br label %bb2
  84. bb1: ; preds = %bb2
  85. %1 = load i32, i32* %l_52, align 4 ; <i32> [#uses=1]
  86. %2 = call i32 @safe_sub_func_uint64_t_u_u(i32 %1, i32 1) nounwind ; <i32> [#uses=1]
  87. store i32 %2, i32* %l_52, align 4
  88. br label %bb2
  89. bb2: ; preds = %bb1, %bb
  90. %3 = load i32, i32* %l_52, align 4 ; <i32> [#uses=1]
  91. %4 = icmp eq i32 %3, 0 ; <i1> [#uses=1]
  92. br i1 %4, label %bb1, label %bb3
  93. bb3: ; preds = %bb2
  94. %5 = load i32, i32* %l_52, align 4 ; <i32> [#uses=1]
  95. %6 = call signext i8 @safe_sub_func_int32_t_s_s(i32 %5, i8 signext 1) nounwind ; <i8> [#uses=1]
  96. %7 = sext i8 %6 to i32 ; <i32> [#uses=1]
  97. store i32 %7, i32* %l_52, align 4
  98. br label %bb4
  99. bb4: ; preds = %bb3, %entry
  100. %8 = load i32, i32* %l_52, align 4 ; <i32> [#uses=1]
  101. %9 = icmp ne i32 %8, 0 ; <i1> [#uses=1]
  102. br i1 %9, label %bb, label %bb5
  103. bb5: ; preds = %bb4
  104. br label %return
  105. return: ; preds = %bb5
  106. ret void
  107. }