backedge-on-min-max.ll 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453
  1. ; RUN: opt < %s -indvars -S | FileCheck %s
  2. ;; --- signed ---
  3. define void @min.signed.1(i32* %a, i32 %a_len, i32 %n) {
  4. ; CHECK-LABEL: @min.signed.1
  5. entry:
  6. %smin.cmp = icmp slt i32 %a_len, %n
  7. %smin = select i1 %smin.cmp, i32 %a_len, i32 %n
  8. %entry.cond = icmp slt i32 0, %smin
  9. br i1 %entry.cond, label %loop, label %exit
  10. loop:
  11. %idx = phi i32 [ 0, %entry ], [ %idx.inc, %latch ]
  12. %idx.inc = add i32 %idx, 1
  13. %in.bounds = icmp slt i32 %idx, %a_len
  14. br i1 %in.bounds, label %ok, label %latch
  15. ; CHECK: br i1 true, label %ok, label %latch
  16. ok:
  17. %addr = getelementptr i32, i32* %a, i32 %idx
  18. store i32 %idx, i32* %addr
  19. br label %latch
  20. latch:
  21. %be.cond = icmp slt i32 %idx.inc, %smin
  22. br i1 %be.cond, label %loop, label %exit
  23. exit:
  24. ret void
  25. }
  26. define void @min.signed.2(i32* %a, i32 %a_len, i32 %n) {
  27. ; CHECK-LABEL: @min.signed.2
  28. entry:
  29. %smin.cmp = icmp slt i32 %a_len, %n
  30. %smin = select i1 %smin.cmp, i32 %a_len, i32 %n
  31. %entry.cond = icmp slt i32 0, %smin
  32. br i1 %entry.cond, label %loop, label %exit
  33. loop:
  34. %idx = phi i32 [ 0, %entry ], [ %idx.inc, %latch ]
  35. %idx.inc = add i32 %idx, 1
  36. %in.bounds = icmp sgt i32 %a_len, %idx
  37. br i1 %in.bounds, label %ok, label %latch
  38. ; CHECK: br i1 true, label %ok, label %latch
  39. ok:
  40. %addr = getelementptr i32, i32* %a, i32 %idx
  41. store i32 %idx, i32* %addr
  42. br label %latch
  43. latch:
  44. %be.cond = icmp slt i32 %idx.inc, %smin
  45. br i1 %be.cond, label %loop, label %exit
  46. exit:
  47. ret void
  48. }
  49. define void @min.signed.3(i32* %a, i32 %n) {
  50. ; CHECK-LABEL: @min.signed.3
  51. entry:
  52. %smin.cmp = icmp slt i32 42, %n
  53. %smin = select i1 %smin.cmp, i32 42, i32 %n
  54. %entry.cond = icmp slt i32 0, %smin
  55. br i1 %entry.cond, label %loop, label %exit
  56. loop:
  57. %idx = phi i32 [ 0, %entry ], [ %idx.inc, %latch ]
  58. %idx.inc = add i32 %idx, 1
  59. %in.bounds = icmp slt i32 %idx, 42
  60. br i1 %in.bounds, label %ok, label %latch
  61. ; CHECK: br i1 true, label %ok, label %latch
  62. ok:
  63. %addr = getelementptr i32, i32* %a, i32 %idx
  64. store i32 %idx, i32* %addr
  65. br label %latch
  66. latch:
  67. %be.cond = icmp slt i32 %idx.inc, %smin
  68. br i1 %be.cond, label %loop, label %exit
  69. exit:
  70. ret void
  71. }
  72. define void @min.signed.4(i32* %a, i32 %n) {
  73. ; CHECK-LABEL: @min.signed.4
  74. entry:
  75. %smin.cmp = icmp slt i32 42, %n
  76. %smin = select i1 %smin.cmp, i32 42, i32 %n
  77. %entry.cond = icmp slt i32 0, %smin
  78. br i1 %entry.cond, label %loop, label %exit
  79. loop:
  80. %idx = phi i32 [ 0, %entry ], [ %idx.inc, %latch ]
  81. %idx.inc = add i32 %idx, 1
  82. %in.bounds = icmp sgt i32 42, %idx
  83. br i1 %in.bounds, label %ok, label %latch
  84. ; CHECK: br i1 true, label %ok, label %latch
  85. ok:
  86. %addr = getelementptr i32, i32* %a, i32 %idx
  87. store i32 %idx, i32* %addr
  88. br label %latch
  89. latch:
  90. %be.cond = icmp slt i32 %idx.inc, %smin
  91. br i1 %be.cond, label %loop, label %exit
  92. exit:
  93. ret void
  94. }
  95. define void @max.signed.1(i32* %a, i32 %a_len, i32 %n) {
  96. ; CHECK-LABEL: @max.signed.1
  97. entry:
  98. %smax.cmp = icmp sgt i32 %a_len, %n
  99. %smax = select i1 %smax.cmp, i32 %a_len, i32 %n
  100. %entry.cond = icmp sgt i32 0, %smax
  101. br i1 %entry.cond, label %loop, label %exit
  102. loop:
  103. %idx = phi i32 [ 0, %entry ], [ %idx.inc, %latch ]
  104. %idx.inc = add i32 %idx, 1
  105. %in.bounds = icmp sgt i32 %idx, %a_len
  106. br i1 %in.bounds, label %ok, label %latch
  107. ; CHECK: br i1 true, label %ok, label %latch
  108. ok:
  109. %addr = getelementptr i32, i32* %a, i32 %idx
  110. store i32 %idx, i32* %addr
  111. br label %latch
  112. latch:
  113. %be.cond = icmp sgt i32 %idx.inc, %smax
  114. br i1 %be.cond, label %loop, label %exit
  115. exit:
  116. ret void
  117. }
  118. define void @max.signed.2(i32* %a, i32 %a_len, i32 %n) {
  119. ; CHECK-LABEL: @max.signed.2
  120. entry:
  121. %smax.cmp = icmp sgt i32 %a_len, %n
  122. %smax = select i1 %smax.cmp, i32 %a_len, i32 %n
  123. %entry.cond = icmp sgt i32 0, %smax
  124. br i1 %entry.cond, label %loop, label %exit
  125. loop:
  126. %idx = phi i32 [ 0, %entry ], [ %idx.inc, %latch ]
  127. %idx.inc = add i32 %idx, 1
  128. %in.bounds = icmp slt i32 %a_len, %idx
  129. br i1 %in.bounds, label %ok, label %latch
  130. ; CHECK: br i1 true, label %ok, label %latch
  131. ok:
  132. %addr = getelementptr i32, i32* %a, i32 %idx
  133. store i32 %idx, i32* %addr
  134. br label %latch
  135. latch:
  136. %be.cond = icmp sgt i32 %idx.inc, %smax
  137. br i1 %be.cond, label %loop, label %exit
  138. exit:
  139. ret void
  140. }
  141. define void @max.signed.3(i32* %a, i32 %n, i32 %init) {
  142. ; CHECK-LABEL: @max.signed.3
  143. entry:
  144. %smax.cmp = icmp sgt i32 42, %n
  145. %smax = select i1 %smax.cmp, i32 42, i32 %n
  146. %entry.cond = icmp sgt i32 %init, %smax
  147. br i1 %entry.cond, label %loop, label %exit
  148. loop:
  149. %idx = phi i32 [ %init, %entry ], [ %idx.inc, %latch ]
  150. %idx.inc = add i32 %idx, 1
  151. %in.bounds = icmp sgt i32 %idx, 42
  152. br i1 %in.bounds, label %ok, label %latch
  153. ; CHECK: br i1 true, label %ok, label %latch
  154. ok:
  155. %addr = getelementptr i32, i32* %a, i32 %idx
  156. store i32 %idx, i32* %addr
  157. br label %latch
  158. latch:
  159. %be.cond = icmp sgt i32 %idx.inc, %smax
  160. br i1 %be.cond, label %loop, label %exit
  161. exit:
  162. ret void
  163. }
  164. define void @max.signed.4(i32* %a, i32 %n, i32 %init) {
  165. ; CHECK-LABEL: @max.signed.4
  166. entry:
  167. %smax.cmp = icmp sgt i32 42, %n
  168. %smax = select i1 %smax.cmp, i32 42, i32 %n
  169. %entry.cond = icmp sgt i32 %init, %smax
  170. br i1 %entry.cond, label %loop, label %exit
  171. loop:
  172. %idx = phi i32 [ %init, %entry ], [ %idx.inc, %latch ]
  173. %idx.inc = add i32 %idx, 1
  174. %in.bounds = icmp slt i32 42, %idx
  175. br i1 %in.bounds, label %ok, label %latch
  176. ; CHECK: br i1 true, label %ok, label %latch
  177. ok:
  178. %addr = getelementptr i32, i32* %a, i32 %idx
  179. store i32 %idx, i32* %addr
  180. br label %latch
  181. latch:
  182. %be.cond = icmp sgt i32 %idx.inc, %smax
  183. br i1 %be.cond, label %loop, label %exit
  184. exit:
  185. ret void
  186. }
  187. ;; --- unsigned ---
  188. define void @min.unsigned.1(i32* %a, i32 %a_len, i32 %n) {
  189. ; CHECK-LABEL: @min.unsigned.1
  190. entry:
  191. %umin.cmp = icmp ult i32 %a_len, %n
  192. %umin = select i1 %umin.cmp, i32 %a_len, i32 %n
  193. %entry.cond = icmp ult i32 5, %umin
  194. br i1 %entry.cond, label %loop, label %exit
  195. loop:
  196. %idx = phi i32 [ 5, %entry ], [ %idx.inc, %latch ]
  197. %idx.inc = add i32 %idx, 1
  198. %in.bounds = icmp ult i32 %idx, %a_len
  199. br i1 %in.bounds, label %ok, label %latch
  200. ; CHECK: br i1 true, label %ok, label %latch
  201. ok:
  202. %addr = getelementptr i32, i32* %a, i32 %idx
  203. store i32 %idx, i32* %addr
  204. br label %latch
  205. latch:
  206. %be.cond = icmp ult i32 %idx.inc, %umin
  207. br i1 %be.cond, label %loop, label %exit
  208. exit:
  209. ret void
  210. }
  211. define void @min.unsigned.2(i32* %a, i32 %a_len, i32 %n) {
  212. ; CHECK-LABEL: @min.unsigned.2
  213. entry:
  214. %umin.cmp = icmp ult i32 %a_len, %n
  215. %umin = select i1 %umin.cmp, i32 %a_len, i32 %n
  216. %entry.cond = icmp ult i32 5, %umin
  217. br i1 %entry.cond, label %loop, label %exit
  218. loop:
  219. %idx = phi i32 [ 5, %entry ], [ %idx.inc, %latch ]
  220. %idx.inc = add i32 %idx, 1
  221. %in.bounds = icmp ugt i32 %a_len, %idx
  222. br i1 %in.bounds, label %ok, label %latch
  223. ; CHECK: br i1 true, label %ok, label %latch
  224. ok:
  225. %addr = getelementptr i32, i32* %a, i32 %idx
  226. store i32 %idx, i32* %addr
  227. br label %latch
  228. latch:
  229. %be.cond = icmp ult i32 %idx.inc, %umin
  230. br i1 %be.cond, label %loop, label %exit
  231. exit:
  232. ret void
  233. }
  234. define void @min.unsigned.3(i32* %a, i32 %n) {
  235. ; CHECK-LABEL: @min.unsigned.3
  236. entry:
  237. %umin.cmp = icmp ult i32 42, %n
  238. %umin = select i1 %umin.cmp, i32 42, i32 %n
  239. %entry.cond = icmp ult i32 5, %umin
  240. br i1 %entry.cond, label %loop, label %exit
  241. loop:
  242. %idx = phi i32 [ 5, %entry ], [ %idx.inc, %latch ]
  243. %idx.inc = add i32 %idx, 1
  244. %in.bounds = icmp ult i32 %idx, 42
  245. br i1 %in.bounds, label %ok, label %latch
  246. ; CHECK: br i1 true, label %ok, label %latch
  247. ok:
  248. %addr = getelementptr i32, i32* %a, i32 %idx
  249. store i32 %idx, i32* %addr
  250. br label %latch
  251. latch:
  252. %be.cond = icmp ult i32 %idx.inc, %umin
  253. br i1 %be.cond, label %loop, label %exit
  254. exit:
  255. ret void
  256. }
  257. define void @min.unsigned.4(i32* %a, i32 %n) {
  258. ; CHECK-LABEL: @min.unsigned.4
  259. entry:
  260. %umin.cmp = icmp ult i32 42, %n
  261. %umin = select i1 %umin.cmp, i32 42, i32 %n
  262. %entry.cond = icmp ult i32 5, %umin
  263. br i1 %entry.cond, label %loop, label %exit
  264. loop:
  265. %idx = phi i32 [ 5, %entry ], [ %idx.inc, %latch ]
  266. %idx.inc = add i32 %idx, 1
  267. %in.bounds = icmp ugt i32 42, %idx
  268. br i1 %in.bounds, label %ok, label %latch
  269. ; CHECK: br i1 true, label %ok, label %latch
  270. ok:
  271. %addr = getelementptr i32, i32* %a, i32 %idx
  272. store i32 %idx, i32* %addr
  273. br label %latch
  274. latch:
  275. %be.cond = icmp ult i32 %idx.inc, %umin
  276. br i1 %be.cond, label %loop, label %exit
  277. exit:
  278. ret void
  279. }
  280. define void @max.unsigned.1(i32* %a, i32 %a_len, i32 %n) {
  281. ; CHECK-LABEL: @max.unsigned.1
  282. entry:
  283. %umax.cmp = icmp ugt i32 %a_len, %n
  284. %umax = select i1 %umax.cmp, i32 %a_len, i32 %n
  285. %entry.cond = icmp ugt i32 5, %umax
  286. br i1 %entry.cond, label %loop, label %exit
  287. loop:
  288. %idx = phi i32 [ 5, %entry ], [ %idx.inc, %latch ]
  289. %idx.inc = add i32 %idx, 1
  290. %in.bounds = icmp ugt i32 %idx, %a_len
  291. br i1 %in.bounds, label %ok, label %latch
  292. ; CHECK: br i1 true, label %ok, label %latch
  293. ok:
  294. %addr = getelementptr i32, i32* %a, i32 %idx
  295. store i32 %idx, i32* %addr
  296. br label %latch
  297. latch:
  298. %be.cond = icmp ugt i32 %idx.inc, %umax
  299. br i1 %be.cond, label %loop, label %exit
  300. exit:
  301. ret void
  302. }
  303. define void @max.unsigned.2(i32* %a, i32 %a_len, i32 %n) {
  304. ; CHECK-LABEL: @max.unsigned.2
  305. entry:
  306. %umax.cmp = icmp ugt i32 %a_len, %n
  307. %umax = select i1 %umax.cmp, i32 %a_len, i32 %n
  308. %entry.cond = icmp ugt i32 5, %umax
  309. br i1 %entry.cond, label %loop, label %exit
  310. loop:
  311. %idx = phi i32 [ 5, %entry ], [ %idx.inc, %latch ]
  312. %idx.inc = add i32 %idx, 1
  313. %in.bounds = icmp ult i32 %a_len, %idx
  314. br i1 %in.bounds, label %ok, label %latch
  315. ; CHECK: br i1 true, label %ok, label %latch
  316. ok:
  317. %addr = getelementptr i32, i32* %a, i32 %idx
  318. store i32 %idx, i32* %addr
  319. br label %latch
  320. latch:
  321. %be.cond = icmp ugt i32 %idx.inc, %umax
  322. br i1 %be.cond, label %loop, label %exit
  323. exit:
  324. ret void
  325. }
  326. define void @max.unsigned.3(i32* %a, i32 %n, i32 %init) {
  327. ; CHECK-LABEL: @max.unsigned.3
  328. entry:
  329. %umax.cmp = icmp ugt i32 42, %n
  330. %umax = select i1 %umax.cmp, i32 42, i32 %n
  331. %entry.cond = icmp ugt i32 %init, %umax
  332. br i1 %entry.cond, label %loop, label %exit
  333. loop:
  334. %idx = phi i32 [ %init, %entry ], [ %idx.inc, %latch ]
  335. %idx.inc = add i32 %idx, 1
  336. %in.bounds = icmp ugt i32 %idx, 42
  337. br i1 %in.bounds, label %ok, label %latch
  338. ; CHECK: br i1 true, label %ok, label %latch
  339. ok:
  340. %addr = getelementptr i32, i32* %a, i32 %idx
  341. store i32 %idx, i32* %addr
  342. br label %latch
  343. latch:
  344. %be.cond = icmp ugt i32 %idx.inc, %umax
  345. br i1 %be.cond, label %loop, label %exit
  346. exit:
  347. ret void
  348. }
  349. define void @max.unsigned.4(i32* %a, i32 %n, i32 %init) {
  350. ; CHECK-LABEL: @max.unsigned.4
  351. entry:
  352. %umax.cmp = icmp ugt i32 42, %n
  353. %umax = select i1 %umax.cmp, i32 42, i32 %n
  354. %entry.cond = icmp ugt i32 %init, %umax
  355. br i1 %entry.cond, label %loop, label %exit
  356. loop:
  357. %idx = phi i32 [ %init, %entry ], [ %idx.inc, %latch ]
  358. %idx.inc = add i32 %idx, 1
  359. %in.bounds = icmp ult i32 42, %idx
  360. br i1 %in.bounds, label %ok, label %latch
  361. ; CHECK: br i1 true, label %ok, label %latch
  362. ok:
  363. %addr = getelementptr i32, i32* %a, i32 %idx
  364. store i32 %idx, i32* %addr
  365. br label %latch
  366. latch:
  367. %be.cond = icmp ugt i32 %idx.inc, %umax
  368. br i1 %be.cond, label %loop, label %exit
  369. exit:
  370. ret void
  371. }