overflow-ops.ll 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. ; RUN: opt < %s -constprop -S | FileCheck %s
  2. declare {i8, i1} @llvm.uadd.with.overflow.i8(i8, i8)
  3. declare {i8, i1} @llvm.usub.with.overflow.i8(i8, i8)
  4. declare {i8, i1} @llvm.umul.with.overflow.i8(i8, i8)
  5. declare {i8, i1} @llvm.sadd.with.overflow.i8(i8, i8)
  6. declare {i8, i1} @llvm.ssub.with.overflow.i8(i8, i8)
  7. declare {i8, i1} @llvm.smul.with.overflow.i8(i8, i8)
  8. ;;-----------------------------
  9. ;; uadd
  10. ;;-----------------------------
  11. define {i8, i1} @uadd_1() nounwind {
  12. entry:
  13. %t = call {i8, i1} @llvm.uadd.with.overflow.i8(i8 42, i8 100)
  14. ret {i8, i1} %t
  15. ; CHECK-LABEL: @uadd_1(
  16. ; CHECK: ret { i8, i1 } { i8 -114, i1 false }
  17. }
  18. define {i8, i1} @uadd_2() nounwind {
  19. entry:
  20. %t = call {i8, i1} @llvm.uadd.with.overflow.i8(i8 142, i8 120)
  21. ret {i8, i1} %t
  22. ; CHECK-LABEL: @uadd_2(
  23. ; CHECK: ret { i8, i1 } { i8 6, i1 true }
  24. }
  25. ;;-----------------------------
  26. ;; usub
  27. ;;-----------------------------
  28. define {i8, i1} @usub_1() nounwind {
  29. entry:
  30. %t = call {i8, i1} @llvm.usub.with.overflow.i8(i8 4, i8 2)
  31. ret {i8, i1} %t
  32. ; CHECK-LABEL: @usub_1(
  33. ; CHECK: ret { i8, i1 } { i8 2, i1 false }
  34. }
  35. define {i8, i1} @usub_2() nounwind {
  36. entry:
  37. %t = call {i8, i1} @llvm.usub.with.overflow.i8(i8 4, i8 6)
  38. ret {i8, i1} %t
  39. ; CHECK-LABEL: @usub_2(
  40. ; CHECK: ret { i8, i1 } { i8 -2, i1 true }
  41. }
  42. ;;-----------------------------
  43. ;; umul
  44. ;;-----------------------------
  45. define {i8, i1} @umul_1() nounwind {
  46. entry:
  47. %t = call {i8, i1} @llvm.umul.with.overflow.i8(i8 100, i8 3)
  48. ret {i8, i1} %t
  49. ; CHECK-LABEL: @umul_1(
  50. ; CHECK: ret { i8, i1 } { i8 44, i1 true }
  51. }
  52. define {i8, i1} @umul_2() nounwind {
  53. entry:
  54. %t = call {i8, i1} @llvm.umul.with.overflow.i8(i8 100, i8 2)
  55. ret {i8, i1} %t
  56. ; CHECK-LABEL: @umul_2(
  57. ; CHECK: ret { i8, i1 } { i8 -56, i1 false }
  58. }
  59. ;;-----------------------------
  60. ;; sadd
  61. ;;-----------------------------
  62. define {i8, i1} @sadd_1() nounwind {
  63. entry:
  64. %t = call {i8, i1} @llvm.sadd.with.overflow.i8(i8 42, i8 2)
  65. ret {i8, i1} %t
  66. ; CHECK-LABEL: @sadd_1(
  67. ; CHECK: ret { i8, i1 } { i8 44, i1 false }
  68. }
  69. define {i8, i1} @sadd_2() nounwind {
  70. entry:
  71. %t = call {i8, i1} @llvm.sadd.with.overflow.i8(i8 120, i8 10)
  72. ret {i8, i1} %t
  73. ; CHECK-LABEL: @sadd_2(
  74. ; CHECK: ret { i8, i1 } { i8 -126, i1 true }
  75. }
  76. define {i8, i1} @sadd_3() nounwind {
  77. entry:
  78. %t = call {i8, i1} @llvm.sadd.with.overflow.i8(i8 -120, i8 10)
  79. ret {i8, i1} %t
  80. ; CHECK-LABEL: @sadd_3(
  81. ; CHECK: ret { i8, i1 } { i8 -110, i1 false }
  82. }
  83. define {i8, i1} @sadd_4() nounwind {
  84. entry:
  85. %t = call {i8, i1} @llvm.sadd.with.overflow.i8(i8 -120, i8 -10)
  86. ret {i8, i1} %t
  87. ; CHECK-LABEL: @sadd_4(
  88. ; CHECK: ret { i8, i1 } { i8 126, i1 true }
  89. }
  90. define {i8, i1} @sadd_5() nounwind {
  91. entry:
  92. %t = call {i8, i1} @llvm.sadd.with.overflow.i8(i8 2, i8 -10)
  93. ret {i8, i1} %t
  94. ; CHECK-LABEL: @sadd_5(
  95. ; CHECK: ret { i8, i1 } { i8 -8, i1 false }
  96. }
  97. ;;-----------------------------
  98. ;; ssub
  99. ;;-----------------------------
  100. define {i8, i1} @ssub_1() nounwind {
  101. entry:
  102. %t = call {i8, i1} @llvm.ssub.with.overflow.i8(i8 4, i8 2)
  103. ret {i8, i1} %t
  104. ; CHECK-LABEL: @ssub_1(
  105. ; CHECK: ret { i8, i1 } { i8 2, i1 false }
  106. }
  107. define {i8, i1} @ssub_2() nounwind {
  108. entry:
  109. %t = call {i8, i1} @llvm.ssub.with.overflow.i8(i8 4, i8 6)
  110. ret {i8, i1} %t
  111. ; CHECK-LABEL: @ssub_2(
  112. ; CHECK: ret { i8, i1 } { i8 -2, i1 false }
  113. }
  114. define {i8, i1} @ssub_3() nounwind {
  115. entry:
  116. %t = call {i8, i1} @llvm.ssub.with.overflow.i8(i8 -10, i8 120)
  117. ret {i8, i1} %t
  118. ; CHECK-LABEL: @ssub_3(
  119. ; CHECK: ret { i8, i1 } { i8 126, i1 true }
  120. }
  121. define {i8, i1} @ssub_3b() nounwind {
  122. entry:
  123. %t = call {i8, i1} @llvm.ssub.with.overflow.i8(i8 -10, i8 10)
  124. ret {i8, i1} %t
  125. ; CHECK-LABEL: @ssub_3b(
  126. ; CHECK: ret { i8, i1 } { i8 -20, i1 false }
  127. }
  128. define {i8, i1} @ssub_4() nounwind {
  129. entry:
  130. %t = call {i8, i1} @llvm.ssub.with.overflow.i8(i8 120, i8 -10)
  131. ret {i8, i1} %t
  132. ; CHECK-LABEL: @ssub_4(
  133. ; CHECK: ret { i8, i1 } { i8 -126, i1 true }
  134. }
  135. define {i8, i1} @ssub_4b() nounwind {
  136. entry:
  137. %t = call {i8, i1} @llvm.ssub.with.overflow.i8(i8 20, i8 -10)
  138. ret {i8, i1} %t
  139. ; CHECK-LABEL: @ssub_4b(
  140. ; CHECK: ret { i8, i1 } { i8 30, i1 false }
  141. }
  142. define {i8, i1} @ssub_5() nounwind {
  143. entry:
  144. %t = call {i8, i1} @llvm.ssub.with.overflow.i8(i8 -20, i8 -10)
  145. ret {i8, i1} %t
  146. ; CHECK-LABEL: @ssub_5(
  147. ; CHECK: ret { i8, i1 } { i8 -10, i1 false }
  148. }
  149. ;;-----------------------------
  150. ;; smul
  151. ;;-----------------------------
  152. ; rdar://8501501
  153. define {i8, i1} @smul_1() nounwind {
  154. entry:
  155. %t = call {i8, i1} @llvm.smul.with.overflow.i8(i8 -20, i8 -10)
  156. ret {i8, i1} %t
  157. ; CHECK-LABEL: @smul_1(
  158. ; CHECK: ret { i8, i1 } { i8 -56, i1 true }
  159. }