sub.ll 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574
  1. target datalayout = "e-p:64:64:64-p1:16:16:16-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
  2. ; Optimize subtracts.
  3. ;
  4. ; RUN: opt < %s -instcombine -S | FileCheck %s
  5. define i32 @test1(i32 %A) {
  6. %B = sub i32 %A, %A
  7. ret i32 %B
  8. ; CHECK-LABEL: @test1(
  9. ; CHECK: ret i32 0
  10. }
  11. define i32 @test2(i32 %A) {
  12. %B = sub i32 %A, 0
  13. ret i32 %B
  14. ; CHECK-LABEL: @test2(
  15. ; CHECK: ret i32 %A
  16. }
  17. define i32 @test3(i32 %A) {
  18. %B = sub i32 0, %A
  19. %C = sub i32 0, %B
  20. ret i32 %C
  21. ; CHECK-LABEL: @test3(
  22. ; CHECK: ret i32 %A
  23. }
  24. define i32 @test4(i32 %A, i32 %x) {
  25. %B = sub i32 0, %A
  26. %C = sub i32 %x, %B
  27. ret i32 %C
  28. ; CHECK-LABEL: @test4(
  29. ; CHECK: %C = add i32 %x, %A
  30. ; CHECK: ret i32 %C
  31. }
  32. define i32 @test5(i32 %A, i32 %B, i32 %C) {
  33. %D = sub i32 %B, %C
  34. %E = sub i32 %A, %D
  35. ret i32 %E
  36. ; CHECK-LABEL: @test5(
  37. ; CHECK: %D1 = sub i32 %C, %B
  38. ; CHECK: %E = add
  39. ; CHECK: ret i32 %E
  40. }
  41. define i32 @test6(i32 %A, i32 %B) {
  42. %C = and i32 %A, %B
  43. %D = sub i32 %A, %C
  44. ret i32 %D
  45. ; CHECK-LABEL: @test6(
  46. ; CHECK-NEXT: xor i32 %B, -1
  47. ; CHECK-NEXT: %D = and i32
  48. ; CHECK-NEXT: ret i32 %D
  49. }
  50. define i32 @test7(i32 %A) {
  51. %B = sub i32 -1, %A
  52. ret i32 %B
  53. ; CHECK-LABEL: @test7(
  54. ; CHECK: %B = xor i32 %A, -1
  55. ; CHECK: ret i32 %B
  56. }
  57. define i32 @test8(i32 %A) {
  58. %B = mul i32 9, %A
  59. %C = sub i32 %B, %A
  60. ret i32 %C
  61. ; CHECK-LABEL: @test8(
  62. ; CHECK: %C = shl i32 %A, 3
  63. ; CHECK: ret i32 %C
  64. }
  65. define i32 @test9(i32 %A) {
  66. %B = mul i32 3, %A
  67. %C = sub i32 %A, %B
  68. ret i32 %C
  69. ; CHECK-LABEL: @test9(
  70. ; CHECK: %C = mul i32 %A, -2
  71. ; CHECK: ret i32 %C
  72. }
  73. define i32 @test10(i32 %A, i32 %B) {
  74. %C = sub i32 0, %A
  75. %D = sub i32 0, %B
  76. %E = mul i32 %C, %D
  77. ret i32 %E
  78. ; CHECK-LABEL: @test10(
  79. ; CHECK: %E = mul i32 %A, %B
  80. ; CHECK: ret i32 %E
  81. }
  82. define i32 @test10a(i32 %A) {
  83. %C = sub i32 0, %A
  84. %E = mul i32 %C, 7
  85. ret i32 %E
  86. ; CHECK-LABEL: @test10a(
  87. ; CHECK: %E = mul i32 %A, -7
  88. ; CHECK: ret i32 %E
  89. }
  90. define i1 @test11(i8 %A, i8 %B) {
  91. %C = sub i8 %A, %B
  92. %cD = icmp ne i8 %C, 0
  93. ret i1 %cD
  94. ; CHECK-LABEL: @test11(
  95. ; CHECK: %cD = icmp ne i8 %A, %B
  96. ; CHECK: ret i1 %cD
  97. }
  98. define i32 @test12(i32 %A) {
  99. %B = ashr i32 %A, 31
  100. %C = sub i32 0, %B
  101. ret i32 %C
  102. ; CHECK-LABEL: @test12(
  103. ; CHECK: %C = lshr i32 %A, 31
  104. ; CHECK: ret i32 %C
  105. }
  106. define i32 @test13(i32 %A) {
  107. %B = lshr i32 %A, 31
  108. %C = sub i32 0, %B
  109. ret i32 %C
  110. ; CHECK-LABEL: @test13(
  111. ; CHECK: %C = ashr i32 %A, 31
  112. ; CHECK: ret i32 %C
  113. }
  114. define i32 @test14(i32 %A) {
  115. %B = lshr i32 %A, 31
  116. %C = bitcast i32 %B to i32
  117. %D = sub i32 0, %C
  118. ret i32 %D
  119. ; CHECK-LABEL: @test14(
  120. ; CHECK: %D = ashr i32 %A, 31
  121. ; CHECK: ret i32 %D
  122. }
  123. define i32 @test15(i32 %A, i32 %B) {
  124. %C = sub i32 0, %A
  125. %D = srem i32 %B, %C
  126. ret i32 %D
  127. ; CHECK-LABEL: @test15(
  128. ; CHECK: %[[sub:.*]] = sub i32 0, %A
  129. ; CHECK-NEXT: %[[rem:.*]] = srem i32 %B, %[[sub]]
  130. ; CHECK: ret i32 %[[rem]]
  131. }
  132. define i32 @test16(i32 %A) {
  133. %X = sdiv i32 %A, 1123
  134. %Y = sub i32 0, %X
  135. ret i32 %Y
  136. ; CHECK-LABEL: @test16(
  137. ; CHECK: %Y = sdiv i32 %A, -1123
  138. ; CHECK: ret i32 %Y
  139. }
  140. ; Can't fold subtract here because negation it might oveflow.
  141. ; PR3142
  142. define i32 @test17(i32 %A) {
  143. %B = sub i32 0, %A
  144. %C = sdiv i32 %B, 1234
  145. ret i32 %C
  146. ; CHECK-LABEL: @test17(
  147. ; CHECK: %B = sub i32 0, %A
  148. ; CHECK: %C = sdiv i32 %B, 1234
  149. ; CHECK: ret i32 %C
  150. }
  151. define i64 @test18(i64 %Y) {
  152. %tmp.4 = shl i64 %Y, 2
  153. %tmp.12 = shl i64 %Y, 2
  154. %tmp.8 = sub i64 %tmp.4, %tmp.12
  155. ret i64 %tmp.8
  156. ; CHECK-LABEL: @test18(
  157. ; CHECK: ret i64 0
  158. }
  159. define i32 @test19(i32 %X, i32 %Y) {
  160. %Z = sub i32 %X, %Y
  161. %Q = add i32 %Z, %Y
  162. ret i32 %Q
  163. ; CHECK-LABEL: @test19(
  164. ; CHECK: ret i32 %X
  165. }
  166. define i1 @test20(i32 %g, i32 %h) {
  167. %tmp.2 = sub i32 %g, %h
  168. %tmp.4 = icmp ne i32 %tmp.2, %g
  169. ret i1 %tmp.4
  170. ; CHECK-LABEL: @test20(
  171. ; CHECK: %tmp.4 = icmp ne i32 %h, 0
  172. ; CHECK: ret i1 %tmp.4
  173. }
  174. define i1 @test21(i32 %g, i32 %h) {
  175. %tmp.2 = sub i32 %g, %h
  176. %tmp.4 = icmp ne i32 %tmp.2, %g
  177. ret i1 %tmp.4
  178. ; CHECK-LABEL: @test21(
  179. ; CHECK: %tmp.4 = icmp ne i32 %h, 0
  180. ; CHECK: ret i1 %tmp.4
  181. }
  182. ; PR2298
  183. define zeroext i1 @test22(i32 %a, i32 %b) nounwind {
  184. %tmp2 = sub i32 0, %a
  185. %tmp4 = sub i32 0, %b
  186. %tmp5 = icmp eq i32 %tmp2, %tmp4
  187. ret i1 %tmp5
  188. ; CHECK-LABEL: @test22(
  189. ; CHECK: %tmp5 = icmp eq i32 %b, %a
  190. ; CHECK: ret i1 %tmp5
  191. }
  192. ; rdar://7362831
  193. define i32 @test23(i8* %P, i64 %A){
  194. %B = getelementptr inbounds i8, i8* %P, i64 %A
  195. %C = ptrtoint i8* %B to i64
  196. %D = trunc i64 %C to i32
  197. %E = ptrtoint i8* %P to i64
  198. %F = trunc i64 %E to i32
  199. %G = sub i32 %D, %F
  200. ret i32 %G
  201. ; CHECK-LABEL: @test23(
  202. ; CHECK-NEXT: = trunc i64 %A to i32
  203. ; CHECK-NEXT: ret i32
  204. }
  205. define i8 @test23_as1(i8 addrspace(1)* %P, i16 %A) {
  206. ; CHECK: @test23_as1
  207. ; CHECK-NEXT: = trunc i16 %A to i8
  208. ; CHECK-NEXT: ret i8
  209. %B = getelementptr inbounds i8, i8 addrspace(1)* %P, i16 %A
  210. %C = ptrtoint i8 addrspace(1)* %B to i16
  211. %D = trunc i16 %C to i8
  212. %E = ptrtoint i8 addrspace(1)* %P to i16
  213. %F = trunc i16 %E to i8
  214. %G = sub i8 %D, %F
  215. ret i8 %G
  216. }
  217. define i64 @test24(i8* %P, i64 %A){
  218. %B = getelementptr inbounds i8, i8* %P, i64 %A
  219. %C = ptrtoint i8* %B to i64
  220. %E = ptrtoint i8* %P to i64
  221. %G = sub i64 %C, %E
  222. ret i64 %G
  223. ; CHECK-LABEL: @test24(
  224. ; CHECK-NEXT: ret i64 %A
  225. }
  226. define i16 @test24_as1(i8 addrspace(1)* %P, i16 %A) {
  227. ; CHECK: @test24_as1
  228. ; CHECK-NEXT: ret i16 %A
  229. %B = getelementptr inbounds i8, i8 addrspace(1)* %P, i16 %A
  230. %C = ptrtoint i8 addrspace(1)* %B to i16
  231. %E = ptrtoint i8 addrspace(1)* %P to i16
  232. %G = sub i16 %C, %E
  233. ret i16 %G
  234. }
  235. define i64 @test24a(i8* %P, i64 %A){
  236. %B = getelementptr inbounds i8, i8* %P, i64 %A
  237. %C = ptrtoint i8* %B to i64
  238. %E = ptrtoint i8* %P to i64
  239. %G = sub i64 %E, %C
  240. ret i64 %G
  241. ; CHECK-LABEL: @test24a(
  242. ; CHECK-NEXT: sub i64 0, %A
  243. ; CHECK-NEXT: ret i64
  244. }
  245. define i16 @test24a_as1(i8 addrspace(1)* %P, i16 %A) {
  246. ; CHECK: @test24a_as1
  247. ; CHECK-NEXT: sub i16 0, %A
  248. ; CHECK-NEXT: ret i16
  249. %B = getelementptr inbounds i8, i8 addrspace(1)* %P, i16 %A
  250. %C = ptrtoint i8 addrspace(1)* %B to i16
  251. %E = ptrtoint i8 addrspace(1)* %P to i16
  252. %G = sub i16 %E, %C
  253. ret i16 %G
  254. }
  255. @Arr = external global [42 x i16]
  256. define i64 @test24b(i8* %P, i64 %A){
  257. %B = getelementptr inbounds [42 x i16], [42 x i16]* @Arr, i64 0, i64 %A
  258. %C = ptrtoint i16* %B to i64
  259. %G = sub i64 %C, ptrtoint ([42 x i16]* @Arr to i64)
  260. ret i64 %G
  261. ; CHECK-LABEL: @test24b(
  262. ; CHECK-NEXT: shl nuw i64 %A, 1
  263. ; CHECK-NEXT: ret i64
  264. }
  265. define i64 @test25(i8* %P, i64 %A){
  266. %B = getelementptr inbounds [42 x i16], [42 x i16]* @Arr, i64 0, i64 %A
  267. %C = ptrtoint i16* %B to i64
  268. %G = sub i64 %C, ptrtoint (i16* getelementptr ([42 x i16], [42 x i16]* @Arr, i64 1, i64 0) to i64)
  269. ret i64 %G
  270. ; CHECK-LABEL: @test25(
  271. ; CHECK-NEXT: shl nuw i64 %A, 1
  272. ; CHECK-NEXT: add i64 {{.*}}, -84
  273. ; CHECK-NEXT: ret i64
  274. }
  275. @Arr_as1 = external addrspace(1) global [42 x i16]
  276. define i16 @test25_as1(i8 addrspace(1)* %P, i64 %A) {
  277. ; CHECK: @test25_as1
  278. ; CHECK-NEXT: %1 = trunc i64 %A to i16
  279. ; CHECK-NEXT: shl nuw i16 %1, 1
  280. ; CHECK-NEXT: add i16 {{.*}}, -84
  281. ; CHECK-NEXT: ret i16
  282. %B = getelementptr inbounds [42 x i16], [42 x i16] addrspace(1)* @Arr_as1, i64 0, i64 %A
  283. %C = ptrtoint i16 addrspace(1)* %B to i16
  284. %G = sub i16 %C, ptrtoint (i16 addrspace(1)* getelementptr ([42 x i16], [42 x i16] addrspace(1)* @Arr_as1, i64 1, i64 0) to i16)
  285. ret i16 %G
  286. }
  287. define i32 @test26(i32 %x) {
  288. %shl = shl i32 3, %x
  289. %neg = sub i32 0, %shl
  290. ret i32 %neg
  291. ; CHECK-LABEL: @test26(
  292. ; CHECK-NEXT: shl i32 -3
  293. ; CHECK-NEXT: ret i32
  294. }
  295. define i32 @test27(i32 %x, i32 %y) {
  296. %mul = mul i32 %y, -8
  297. %sub = sub i32 %x, %mul
  298. ret i32 %sub
  299. ; CHECK-LABEL: @test27(
  300. ; CHECK-NEXT: shl i32 %y, 3
  301. ; CHECK-NEXT: add i32
  302. ; CHECK-NEXT: ret i32
  303. }
  304. define i32 @test28(i32 %x, i32 %y, i32 %z) {
  305. %neg = sub i32 0, %z
  306. %mul = mul i32 %neg, %y
  307. %sub = sub i32 %x, %mul
  308. ret i32 %sub
  309. ; CHECK-LABEL: @test28(
  310. ; CHECK-NEXT: mul i32 %z, %y
  311. ; CHECK-NEXT: add i32
  312. ; CHECK-NEXT: ret i32
  313. }
  314. define i64 @test29(i8* %foo, i64 %i, i64 %j) {
  315. %gep1 = getelementptr inbounds i8, i8* %foo, i64 %i
  316. %gep2 = getelementptr inbounds i8, i8* %foo, i64 %j
  317. %cast1 = ptrtoint i8* %gep1 to i64
  318. %cast2 = ptrtoint i8* %gep2 to i64
  319. %sub = sub i64 %cast1, %cast2
  320. ret i64 %sub
  321. ; CHECK-LABEL: @test29(
  322. ; CHECK-NEXT: sub i64 %i, %j
  323. ; CHECK-NEXT: ret i64
  324. }
  325. define i64 @test30(i8* %foo, i64 %i, i64 %j) {
  326. %bit = bitcast i8* %foo to i32*
  327. %gep1 = getelementptr inbounds i32, i32* %bit, i64 %i
  328. %gep2 = getelementptr inbounds i8, i8* %foo, i64 %j
  329. %cast1 = ptrtoint i32* %gep1 to i64
  330. %cast2 = ptrtoint i8* %gep2 to i64
  331. %sub = sub i64 %cast1, %cast2
  332. ret i64 %sub
  333. ; CHECK-LABEL: @test30(
  334. ; CHECK-NEXT: %gep1.idx = shl nuw i64 %i, 2
  335. ; CHECK-NEXT: sub i64 %gep1.idx, %j
  336. ; CHECK-NEXT: ret i64
  337. }
  338. define i16 @test30_as1(i8 addrspace(1)* %foo, i16 %i, i16 %j) {
  339. ; CHECK-LABEL: @test30_as1(
  340. ; CHECK-NEXT: %gep1.idx = shl nuw i16 %i, 2
  341. ; CHECK-NEXT: sub i16 %gep1.idx, %j
  342. ; CHECK-NEXT: ret i16
  343. %bit = bitcast i8 addrspace(1)* %foo to i32 addrspace(1)*
  344. %gep1 = getelementptr inbounds i32, i32 addrspace(1)* %bit, i16 %i
  345. %gep2 = getelementptr inbounds i8, i8 addrspace(1)* %foo, i16 %j
  346. %cast1 = ptrtoint i32 addrspace(1)* %gep1 to i16
  347. %cast2 = ptrtoint i8 addrspace(1)* %gep2 to i16
  348. %sub = sub i16 %cast1, %cast2
  349. ret i16 %sub
  350. }
  351. define <2 x i64> @test31(<2 x i64> %A) {
  352. %xor = xor <2 x i64> %A, <i64 -1, i64 -1>
  353. %sub = sub <2 x i64> <i64 2, i64 3>, %xor
  354. ret <2 x i64> %sub
  355. ; CHECK-LABEL: @test31(
  356. ; CHECK-NEXT: %sub = add <2 x i64> %A, <i64 3, i64 4>
  357. ; CHECK-NEXT: ret <2 x i64> %sub
  358. }
  359. define <2 x i64> @test32(<2 x i64> %A) {
  360. %add = add <2 x i64> %A, <i64 -1, i64 -1>
  361. %sub = sub <2 x i64> <i64 2, i64 3>, %add
  362. ret <2 x i64> %sub
  363. ; CHECK-LABEL: @test32(
  364. ; CHECK-NEXT: %sub = sub <2 x i64> <i64 3, i64 4>
  365. ; CHECK-NEXT: ret <2 x i64> %sub
  366. }
  367. define <2 x i64> @test33(<2 x i1> %A) {
  368. %ext = zext <2 x i1> %A to <2 x i64>
  369. %sub = sub <2 x i64> zeroinitializer, %ext
  370. ret <2 x i64> %sub
  371. ; CHECK-LABEL: @test33(
  372. ; CHECK-NEXT: %sub = sext <2 x i1> %A to <2 x i64>
  373. ; CHECK-NEXT: ret <2 x i64> %sub
  374. }
  375. define <2 x i64> @test34(<2 x i1> %A) {
  376. %ext = sext <2 x i1> %A to <2 x i64>
  377. %sub = sub <2 x i64> zeroinitializer, %ext
  378. ret <2 x i64> %sub
  379. ; CHECK-LABEL: @test34(
  380. ; CHECK-NEXT: %sub = zext <2 x i1> %A to <2 x i64>
  381. ; CHECK-NEXT: ret <2 x i64> %sub
  382. }
  383. define <2 x i64> @test35(<2 x i64> %A) {
  384. %mul = mul <2 x i64> %A, <i64 3, i64 4>
  385. %sub = sub <2 x i64> %A, %mul
  386. ret <2 x i64> %sub
  387. ; CHECK-LABEL: @test35(
  388. ; CHECK-NEXT: %sub = mul <2 x i64> %A, <i64 -2, i64 -3>
  389. ; CHECK-NEXT: ret <2 x i64> %sub
  390. }
  391. define <2 x i64> @test36(<2 x i64> %A) {
  392. %shl = shl <2 x i64> %A, <i64 3, i64 4>
  393. %sub = sub <2 x i64> %shl, %A
  394. ret <2 x i64> %sub
  395. ; CHECK-LABEL: @test36(
  396. ; CHECK-NEXT: %sub = mul <2 x i64> %A, <i64 7, i64 15>
  397. ; CHECK-NEXT: ret <2 x i64> %sub
  398. }
  399. define <2 x i32> @test37(<2 x i32> %A) {
  400. %div = sdiv <2 x i32> %A, <i32 -2147483648, i32 -2147483648>
  401. %sub = sub nsw <2 x i32> zeroinitializer, %div
  402. ret <2 x i32> %sub
  403. ; CHECK-LABEL: @test37(
  404. ; CHECK-NEXT: [[ICMP:%.*]] = icmp eq <2 x i32> %A, <i32 -2147483648, i32 -2147483648>
  405. ; CHECK-NEXT: [[SEXT:%.*]] = sext <2 x i1> [[ICMP]] to <2 x i32>
  406. ; CHECK-NEXT: ret <2 x i32> [[SEXT]]
  407. }
  408. define i32 @test38(i32 %A) {
  409. %div = sdiv i32 %A, -2147483648
  410. %sub = sub nsw i32 0, %div
  411. ret i32 %sub
  412. ; CHECK-LABEL: @test38(
  413. ; CHECK-NEXT: [[ICMP:%.*]] = icmp eq i32 %A, -2147483648
  414. ; CHECK-NEXT: [[SEXT:%.*]] = sext i1 [[ICMP]] to i32
  415. ; CHECK-NEXT: ret i32 [[SEXT]]
  416. }
  417. define i32 @test39(i32 %A, i32 %x) {
  418. %B = sub i32 0, %A
  419. %C = sub nsw i32 %x, %B
  420. ret i32 %C
  421. ; CHECK-LABEL: @test39(
  422. ; CHECK: %C = add i32 %x, %A
  423. ; CHECK: ret i32 %C
  424. }
  425. define i16 @test40(i16 %a, i16 %b) {
  426. %ashr = ashr i16 %a, 1
  427. %ashr1 = ashr i16 %b, 1
  428. %sub = sub i16 %ashr, %ashr1
  429. ret i16 %sub
  430. ; CHECK-LABEL: @test40(
  431. ; CHECK-NEXT: [[ASHR:%.*]] = ashr i16 %a, 1
  432. ; CHECK-NEXT: [[ASHR1:%.*]] = ashr i16 %b, 1
  433. ; CHECK-NEXT: [[RET:%.*]] = sub nsw i16 [[ASHR]], [[ASHR1]]
  434. ; CHECK: ret i16 [[RET]]
  435. }
  436. define i32 @test41(i16 %a, i16 %b) {
  437. %conv = sext i16 %a to i32
  438. %conv1 = sext i16 %b to i32
  439. %sub = sub i32 %conv, %conv1
  440. ret i32 %sub
  441. ; CHECK-LABEL: @test41(
  442. ; CHECK-NEXT: [[SEXT:%.*]] = sext i16 %a to i32
  443. ; CHECK-NEXT: [[SEXT1:%.*]] = sext i16 %b to i32
  444. ; CHECK-NEXT: [[RET:%.*]] = sub nsw i32 [[SEXT]], [[SEXT1]]
  445. ; CHECK: ret i32 [[RET]]
  446. }
  447. define i4 @test42(i4 %x, i4 %y) {
  448. %a = and i4 %y, 7
  449. %b = and i4 %x, 7
  450. %c = sub i4 %a, %b
  451. ret i4 %c
  452. ; CHECK-LABEL: @test42(
  453. ; CHECK-NEXT: [[AND:%.*]] = and i4 %y, 7
  454. ; CHECK-NEXT: [[AND1:%.*]] = and i4 %x, 7
  455. ; CHECK-NEXT: [[RET:%.*]] = sub nsw i4 [[AND]], [[AND1]]
  456. ; CHECK: ret i4 [[RET]]
  457. }
  458. define i4 @test43(i4 %x, i4 %y) {
  459. %a = or i4 %x, -8
  460. %b = and i4 %y, 7
  461. %c = sub i4 %a, %b
  462. ret i4 %c
  463. ; CHECK-LABEL: @test43(
  464. ; CHECK-NEXT: [[OR:%.*]] = or i4 %x, -8
  465. ; CHECK-NEXT: [[AND:%.*]] = and i4 %y, 7
  466. ; CHECK-NEXT: [[RET:%.*]] = sub nuw i4 [[OR]], [[AND]]
  467. ; CHECK: ret i4 [[RET]]
  468. }
  469. define i32 @test44(i32 %x) {
  470. %sub = sub nsw i32 %x, 32768
  471. ret i32 %sub
  472. ; CHECK-LABEL: @test44(
  473. ; CHECK-NEXT: [[ADD:%.*]] = add nsw i32 %x, -32768
  474. ; CHECK: ret i32 [[ADD]]
  475. }
  476. define i32 @test45(i32 %x, i32 %y) {
  477. %or = or i32 %x, %y
  478. %xor = xor i32 %x, %y
  479. %sub = sub i32 %or, %xor
  480. ret i32 %sub
  481. ; CHECK-LABEL: @test45(
  482. ; CHECK-NEXT: %sub = and i32 %x, %y
  483. ; CHECK: ret i32 %sub
  484. }
  485. define i32 @test46(i32 %x, i32 %y) {
  486. %or = or i32 %x, %y
  487. %sub = sub i32 %or, %x
  488. ret i32 %sub
  489. ; CHECK-LABEL: @test46(
  490. ; CHECK-NEXT: %x.not = xor i32 %x, -1
  491. ; CHECK-NEXT: %sub = and i32 %y, %x.not
  492. ; CHECK: ret i32 %sub
  493. }
  494. define i32 @test47(i1 %A, i32 %B, i32 %C, i32 %D) {
  495. %sel0 = select i1 %A, i32 %D, i32 %B
  496. %sel1 = select i1 %A, i32 %C, i32 %B
  497. %sub = sub i32 %sel0, %sel1
  498. ret i32 %sub
  499. ; CHECK-LABEL: @test47(
  500. ; CHECK-NEXT: %[[sub:.*]] = sub i32 %D, %C
  501. ; CHECK-NEXT: %[[sel:.*]] = select i1 %A, i32 %[[sub]], i32 0
  502. ; CHECK-NEXT: ret i32 %[[sel]]
  503. }
  504. define i32 @test48(i1 %A, i32 %B, i32 %C, i32 %D) {
  505. %sel0 = select i1 %A, i32 %B, i32 %D
  506. %sel1 = select i1 %A, i32 %B, i32 %C
  507. %sub = sub i32 %sel0, %sel1
  508. ret i32 %sub
  509. ; CHECK-LABEL: @test48(
  510. ; CHECK-NEXT: %[[sub:.*]] = sub i32 %D, %C
  511. ; CHECK-NEXT: %[[sel:.*]] = select i1 %A, i32 0, i32 %[[sub]]
  512. ; CHECK-NEXT: ret i32 %[[sel]]
  513. }