apint-sub.ll 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. ; This test makes sure that sub instructions are properly eliminated
  2. ; even with arbitrary precision integers.
  3. ;
  4. ; RUN: opt < %s -instcombine -S | \
  5. ; RUN: grep -v "sub i19 %Cok, %Bok" | grep -v "sub i25 0, %Aok" | not grep sub
  6. ; END.
  7. define i23 @test1(i23 %A) {
  8. %B = sub i23 %A, %A ; <i23> [#uses=1]
  9. ret i23 %B
  10. }
  11. define i47 @test2(i47 %A) {
  12. %B = sub i47 %A, 0 ; <i47> [#uses=1]
  13. ret i47 %B
  14. }
  15. define i97 @test3(i97 %A) {
  16. %B = sub i97 0, %A ; <i97> [#uses=1]
  17. %C = sub i97 0, %B ; <i97> [#uses=1]
  18. ret i97 %C
  19. }
  20. define i108 @test4(i108 %A, i108 %x) {
  21. %B = sub i108 0, %A ; <i108> [#uses=1]
  22. %C = sub i108 %x, %B ; <i108> [#uses=1]
  23. ret i108 %C
  24. }
  25. define i19 @test5(i19 %A, i19 %Bok, i19 %Cok) {
  26. %D = sub i19 %Bok, %Cok ; <i19> [#uses=1]
  27. %E = sub i19 %A, %D ; <i19> [#uses=1]
  28. ret i19 %E
  29. }
  30. define i57 @test6(i57 %A, i57 %B) {
  31. %C = and i57 %A, %B ; <i57> [#uses=1]
  32. %D = sub i57 %A, %C ; <i57> [#uses=1]
  33. ret i57 %D
  34. }
  35. define i77 @test7(i77 %A) {
  36. %B = sub i77 -1, %A ; <i77> [#uses=1]
  37. ret i77 %B
  38. }
  39. define i27 @test8(i27 %A) {
  40. %B = mul i27 9, %A ; <i27> [#uses=1]
  41. %C = sub i27 %B, %A ; <i27> [#uses=1]
  42. ret i27 %C
  43. }
  44. define i42 @test9(i42 %A) {
  45. %B = mul i42 3, %A ; <i42> [#uses=1]
  46. %C = sub i42 %A, %B ; <i42> [#uses=1]
  47. ret i42 %C
  48. }
  49. define i124 @test10(i124 %A, i124 %B) {
  50. %C = sub i124 0, %A ; <i124> [#uses=1]
  51. %D = sub i124 0, %B ; <i124> [#uses=1]
  52. %E = mul i124 %C, %D ; <i124> [#uses=1]
  53. ret i124 %E
  54. }
  55. define i55 @test10a(i55 %A) {
  56. %C = sub i55 0, %A ; <i55> [#uses=1]
  57. %E = mul i55 %C, 7 ; <i55> [#uses=1]
  58. ret i55 %E
  59. }
  60. define i1 @test11(i9 %A, i9 %B) {
  61. %C = sub i9 %A, %B ; <i9> [#uses=1]
  62. %cD = icmp ne i9 %C, 0 ; <i1> [#uses=1]
  63. ret i1 %cD
  64. }
  65. define i43 @test12(i43 %A) {
  66. %B = ashr i43 %A, 42 ; <i43> [#uses=1]
  67. %C = sub i43 0, %B ; <i43> [#uses=1]
  68. ret i43 %C
  69. }
  70. define i79 @test13(i79 %A) {
  71. %B = lshr i79 %A, 78 ; <i79> [#uses=1]
  72. %C = sub i79 0, %B ; <i79> [#uses=1]
  73. ret i79 %C
  74. }
  75. define i1024 @test14(i1024 %A) {
  76. %B = lshr i1024 %A, 1023 ; <i1024> [#uses=1]
  77. %C = bitcast i1024 %B to i1024 ; <i1024> [#uses=1]
  78. %D = sub i1024 0, %C ; <i1024> [#uses=1]
  79. ret i1024 %D
  80. }
  81. define i51 @test16(i51 %A) {
  82. %X = sdiv i51 %A, 1123 ; <i51> [#uses=1]
  83. %Y = sub i51 0, %X ; <i51> [#uses=1]
  84. ret i51 %Y
  85. }
  86. ; Can't fold subtract here because negation it might oveflow.
  87. ; PR3142
  88. define i25 @test17(i25 %Aok) {
  89. %B = sub i25 0, %Aok ; <i25> [#uses=1]
  90. %C = sdiv i25 %B, 1234 ; <i25> [#uses=1]
  91. ret i25 %C
  92. }
  93. define i128 @test18(i128 %Y) {
  94. %tmp.4 = shl i128 %Y, 2 ; <i128> [#uses=1]
  95. %tmp.12 = shl i128 %Y, 2 ; <i128> [#uses=1]
  96. %tmp.8 = sub i128 %tmp.4, %tmp.12 ; <i128> [#uses=1]
  97. ret i128 %tmp.8
  98. }
  99. define i39 @test19(i39 %X, i39 %Y) {
  100. %Z = sub i39 %X, %Y ; <i39> [#uses=1]
  101. %Q = add i39 %Z, %Y ; <i39> [#uses=1]
  102. ret i39 %Q
  103. }
  104. define i1 @test20(i33 %g, i33 %h) {
  105. %tmp.2 = sub i33 %g, %h ; <i33> [#uses=1]
  106. %tmp.4 = icmp ne i33 %tmp.2, %g ; <i1> [#uses=1]
  107. ret i1 %tmp.4
  108. }
  109. define i1 @test21(i256 %g, i256 %h) {
  110. %tmp.2 = sub i256 %g, %h ; <i256> [#uses=1]
  111. %tmp.4 = icmp ne i256 %tmp.2, %g; <i1> [#uses=1]
  112. ret i1 %tmp.4
  113. }