apint-add2.ll 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. ; This test makes sure that add instructions are properly eliminated.
  2. ; This test is for Integer BitWidth > 64 && BitWidth <= 1024.
  3. ; RUN: opt < %s -instcombine -S | \
  4. ; RUN: grep -v OK | not grep add
  5. ; END.
  6. define i111 @test1(i111 %x) {
  7. %tmp.2 = shl i111 1, 110
  8. %tmp.4 = xor i111 %x, %tmp.2
  9. ;; Add of sign bit -> xor of sign bit.
  10. %tmp.6 = add i111 %tmp.4, %tmp.2
  11. ret i111 %tmp.6
  12. }
  13. define i65 @test2(i65 %x) {
  14. %tmp.0 = shl i65 1, 64
  15. %tmp.2 = xor i65 %x, %tmp.0
  16. ;; Add of sign bit -> xor of sign bit.
  17. %tmp.4 = add i65 %tmp.2, %tmp.0
  18. ret i65 %tmp.4
  19. }
  20. define i1024 @test3(i1024 %x) {
  21. %tmp.0 = shl i1024 1, 1023
  22. %tmp.2 = xor i1024 %x, %tmp.0
  23. ;; Add of sign bit -> xor of sign bit.
  24. %tmp.4 = add i1024 %tmp.2, %tmp.0
  25. ret i1024 %tmp.4
  26. }
  27. define i128 @test4(i128 %x) {
  28. ;; If we have ADD(XOR(AND(X, 0xFF), 0xF..F80), 0x80), it's a sext.
  29. %tmp.5 = shl i128 1, 127
  30. %tmp.1 = ashr i128 %tmp.5, 120
  31. %tmp.2 = xor i128 %x, %tmp.1
  32. %tmp.4 = add i128 %tmp.2, %tmp.5
  33. ret i128 %tmp.4
  34. }
  35. define i77 @test6(i77 %x) {
  36. ;; (x & 254)+1 -> (x & 254)|1
  37. %tmp.2 = and i77 %x, 562949953421310
  38. %tmp.4 = add i77 %tmp.2, 1
  39. ret i77 %tmp.4
  40. }