flags.ll 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. ; RUN: llvm-as < %s | llvm-dis | FileCheck %s
  2. ; RUN: verify-uselistorder %s
  3. @addr = external global i64
  4. define i64 @add_unsigned(i64 %x, i64 %y) {
  5. ; CHECK: %z = add nuw i64 %x, %y
  6. %z = add nuw i64 %x, %y
  7. ret i64 %z
  8. }
  9. define i64 @sub_unsigned(i64 %x, i64 %y) {
  10. ; CHECK: %z = sub nuw i64 %x, %y
  11. %z = sub nuw i64 %x, %y
  12. ret i64 %z
  13. }
  14. define i64 @mul_unsigned(i64 %x, i64 %y) {
  15. ; CHECK: %z = mul nuw i64 %x, %y
  16. %z = mul nuw i64 %x, %y
  17. ret i64 %z
  18. }
  19. define i64 @add_signed(i64 %x, i64 %y) {
  20. ; CHECK: %z = add nsw i64 %x, %y
  21. %z = add nsw i64 %x, %y
  22. ret i64 %z
  23. }
  24. define i64 @sub_signed(i64 %x, i64 %y) {
  25. ; CHECK: %z = sub nsw i64 %x, %y
  26. %z = sub nsw i64 %x, %y
  27. ret i64 %z
  28. }
  29. define i64 @mul_signed(i64 %x, i64 %y) {
  30. ; CHECK: %z = mul nsw i64 %x, %y
  31. %z = mul nsw i64 %x, %y
  32. ret i64 %z
  33. }
  34. define i64 @add_plain(i64 %x, i64 %y) {
  35. ; CHECK: %z = add i64 %x, %y
  36. %z = add i64 %x, %y
  37. ret i64 %z
  38. }
  39. define i64 @sub_plain(i64 %x, i64 %y) {
  40. ; CHECK: %z = sub i64 %x, %y
  41. %z = sub i64 %x, %y
  42. ret i64 %z
  43. }
  44. define i64 @mul_plain(i64 %x, i64 %y) {
  45. ; CHECK: %z = mul i64 %x, %y
  46. %z = mul i64 %x, %y
  47. ret i64 %z
  48. }
  49. define i64 @add_both(i64 %x, i64 %y) {
  50. ; CHECK: %z = add nuw nsw i64 %x, %y
  51. %z = add nuw nsw i64 %x, %y
  52. ret i64 %z
  53. }
  54. define i64 @sub_both(i64 %x, i64 %y) {
  55. ; CHECK: %z = sub nuw nsw i64 %x, %y
  56. %z = sub nuw nsw i64 %x, %y
  57. ret i64 %z
  58. }
  59. define i64 @mul_both(i64 %x, i64 %y) {
  60. ; CHECK: %z = mul nuw nsw i64 %x, %y
  61. %z = mul nuw nsw i64 %x, %y
  62. ret i64 %z
  63. }
  64. define i64 @add_both_reversed(i64 %x, i64 %y) {
  65. ; CHECK: %z = add nuw nsw i64 %x, %y
  66. %z = add nsw nuw i64 %x, %y
  67. ret i64 %z
  68. }
  69. define i64 @sub_both_reversed(i64 %x, i64 %y) {
  70. ; CHECK: %z = sub nuw nsw i64 %x, %y
  71. %z = sub nsw nuw i64 %x, %y
  72. ret i64 %z
  73. }
  74. define i64 @mul_both_reversed(i64 %x, i64 %y) {
  75. ; CHECK: %z = mul nuw nsw i64 %x, %y
  76. %z = mul nsw nuw i64 %x, %y
  77. ret i64 %z
  78. }
  79. define i64 @shl_both(i64 %x, i64 %y) {
  80. ; CHECK: %z = shl nuw nsw i64 %x, %y
  81. %z = shl nuw nsw i64 %x, %y
  82. ret i64 %z
  83. }
  84. define i64 @sdiv_exact(i64 %x, i64 %y) {
  85. ; CHECK: %z = sdiv exact i64 %x, %y
  86. %z = sdiv exact i64 %x, %y
  87. ret i64 %z
  88. }
  89. define i64 @sdiv_plain(i64 %x, i64 %y) {
  90. ; CHECK: %z = sdiv i64 %x, %y
  91. %z = sdiv i64 %x, %y
  92. ret i64 %z
  93. }
  94. define i64 @udiv_exact(i64 %x, i64 %y) {
  95. ; CHECK: %z = udiv exact i64 %x, %y
  96. %z = udiv exact i64 %x, %y
  97. ret i64 %z
  98. }
  99. define i64 @udiv_plain(i64 %x, i64 %y) {
  100. ; CHECK: %z = udiv i64 %x, %y
  101. %z = udiv i64 %x, %y
  102. ret i64 %z
  103. }
  104. define i64 @ashr_plain(i64 %x, i64 %y) {
  105. ; CHECK: %z = ashr i64 %x, %y
  106. %z = ashr i64 %x, %y
  107. ret i64 %z
  108. }
  109. define i64 @ashr_exact(i64 %x, i64 %y) {
  110. ; CHECK: %z = ashr exact i64 %x, %y
  111. %z = ashr exact i64 %x, %y
  112. ret i64 %z
  113. }
  114. define i64 @lshr_plain(i64 %x, i64 %y) {
  115. ; CHECK: %z = lshr i64 %x, %y
  116. %z = lshr i64 %x, %y
  117. ret i64 %z
  118. }
  119. define i64 @lshr_exact(i64 %x, i64 %y) {
  120. ; CHECK: %z = lshr exact i64 %x, %y
  121. %z = lshr exact i64 %x, %y
  122. ret i64 %z
  123. }
  124. define i64* @gep_nw(i64* %p, i64 %x) {
  125. ; CHECK: %z = getelementptr inbounds i64, i64* %p, i64 %x
  126. %z = getelementptr inbounds i64, i64* %p, i64 %x
  127. ret i64* %z
  128. }
  129. define i64* @gep_plain(i64* %p, i64 %x) {
  130. ; CHECK: %z = getelementptr i64, i64* %p, i64 %x
  131. %z = getelementptr i64, i64* %p, i64 %x
  132. ret i64* %z
  133. }
  134. define i64 @add_both_ce() {
  135. ; CHECK: ret i64 add nuw nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  136. ret i64 add nsw nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  137. }
  138. define i64 @sub_both_ce() {
  139. ; CHECK: ret i64 sub nuw nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  140. ret i64 sub nsw nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  141. }
  142. define i64 @mul_both_ce() {
  143. ; CHECK: ret i64 mul nuw nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  144. ret i64 mul nuw nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  145. }
  146. define i64 @sdiv_exact_ce() {
  147. ; CHECK: ret i64 sdiv exact (i64 ptrtoint (i64* @addr to i64), i64 91)
  148. ret i64 sdiv exact (i64 ptrtoint (i64* @addr to i64), i64 91)
  149. }
  150. define i64 @udiv_exact_ce() {
  151. ; CHECK: ret i64 udiv exact (i64 ptrtoint (i64* @addr to i64), i64 91)
  152. ret i64 udiv exact (i64 ptrtoint (i64* @addr to i64), i64 91)
  153. }
  154. define i64 @ashr_exact_ce() {
  155. ; CHECK: ret i64 ashr exact (i64 ptrtoint (i64* @addr to i64), i64 9)
  156. ret i64 ashr exact (i64 ptrtoint (i64* @addr to i64), i64 9)
  157. }
  158. define i64 @lshr_exact_ce() {
  159. ; CHECK: ret i64 lshr exact (i64 ptrtoint (i64* @addr to i64), i64 9)
  160. ret i64 lshr exact (i64 ptrtoint (i64* @addr to i64), i64 9)
  161. }
  162. define i64* @gep_nw_ce() {
  163. ; CHECK: ret i64* getelementptr inbounds (i64, i64* @addr, i64 171)
  164. ret i64* getelementptr inbounds (i64, i64* @addr, i64 171)
  165. }
  166. define i64 @add_plain_ce() {
  167. ; CHECK: ret i64 add (i64 ptrtoint (i64* @addr to i64), i64 91)
  168. ret i64 add (i64 ptrtoint (i64* @addr to i64), i64 91)
  169. }
  170. define i64 @sub_plain_ce() {
  171. ; CHECK: ret i64 sub (i64 ptrtoint (i64* @addr to i64), i64 91)
  172. ret i64 sub (i64 ptrtoint (i64* @addr to i64), i64 91)
  173. }
  174. define i64 @mul_plain_ce() {
  175. ; CHECK: ret i64 mul (i64 ptrtoint (i64* @addr to i64), i64 91)
  176. ret i64 mul (i64 ptrtoint (i64* @addr to i64), i64 91)
  177. }
  178. define i64 @sdiv_plain_ce() {
  179. ; CHECK: ret i64 sdiv (i64 ptrtoint (i64* @addr to i64), i64 91)
  180. ret i64 sdiv (i64 ptrtoint (i64* @addr to i64), i64 91)
  181. }
  182. define i64* @gep_plain_ce() {
  183. ; CHECK: ret i64* getelementptr (i64, i64* @addr, i64 171)
  184. ret i64* getelementptr (i64, i64* @addr, i64 171)
  185. }
  186. define i64 @add_both_reversed_ce() {
  187. ; CHECK: ret i64 add nuw nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  188. ret i64 add nsw nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  189. }
  190. define i64 @sub_both_reversed_ce() {
  191. ; CHECK: ret i64 sub nuw nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  192. ret i64 sub nsw nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  193. }
  194. define i64 @mul_both_reversed_ce() {
  195. ; CHECK: ret i64 mul nuw nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  196. ret i64 mul nsw nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  197. }
  198. define i64 @add_signed_ce() {
  199. ; CHECK: ret i64 add nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  200. ret i64 add nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  201. }
  202. define i64 @sub_signed_ce() {
  203. ; CHECK: ret i64 sub nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  204. ret i64 sub nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  205. }
  206. define i64 @mul_signed_ce() {
  207. ; CHECK: ret i64 mul nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  208. ret i64 mul nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
  209. }
  210. define i64 @shl_signed_ce() {
  211. ; CHECK: ret i64 shl nsw (i64 ptrtoint (i64* @addr to i64), i64 17)
  212. ret i64 shl nsw (i64 ptrtoint (i64* @addr to i64), i64 17)
  213. }
  214. define i64 @add_unsigned_ce() {
  215. ; CHECK: ret i64 add nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  216. ret i64 add nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  217. }
  218. define i64 @sub_unsigned_ce() {
  219. ; CHECK: ret i64 sub nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  220. ret i64 sub nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  221. }
  222. define i64 @mul_unsigned_ce() {
  223. ; CHECK: ret i64 mul nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  224. ret i64 mul nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
  225. }