2011-07-07-MatchIntrinsicExtract.ll 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. ; RUN: opt < %s -gvn -S | FileCheck %s
  2. ;
  3. %0 = type { i64, i1 }
  4. define i64 @test1(i64 %a, i64 %b) nounwind ssp {
  5. entry:
  6. %uadd = tail call %0 @llvm.uadd.with.overflow.i64(i64 %a, i64 %b)
  7. %uadd.0 = extractvalue %0 %uadd, 0
  8. %add1 = add i64 %a, %b
  9. ret i64 %add1
  10. }
  11. ; CHECK-LABEL: @test1(
  12. ; CHECK-NOT: add1
  13. ; CHECK: ret
  14. define i64 @test2(i64 %a, i64 %b) nounwind ssp {
  15. entry:
  16. %usub = tail call %0 @llvm.usub.with.overflow.i64(i64 %a, i64 %b)
  17. %usub.0 = extractvalue %0 %usub, 0
  18. %sub1 = sub i64 %a, %b
  19. ret i64 %sub1
  20. }
  21. ; CHECK-LABEL: @test2(
  22. ; CHECK-NOT: sub1
  23. ; CHECK: ret
  24. define i64 @test3(i64 %a, i64 %b) nounwind ssp {
  25. entry:
  26. %umul = tail call %0 @llvm.umul.with.overflow.i64(i64 %a, i64 %b)
  27. %umul.0 = extractvalue %0 %umul, 0
  28. %mul1 = mul i64 %a, %b
  29. ret i64 %mul1
  30. }
  31. ; CHECK-LABEL: @test3(
  32. ; CHECK-NOT: mul1
  33. ; CHECK: ret
  34. define i64 @test4(i64 %a, i64 %b) nounwind ssp {
  35. entry:
  36. %sadd = tail call %0 @llvm.sadd.with.overflow.i64(i64 %a, i64 %b)
  37. %sadd.0 = extractvalue %0 %sadd, 0
  38. %add1 = add i64 %a, %b
  39. ret i64 %add1
  40. }
  41. ; CHECK-LABEL: @test4(
  42. ; CHECK-NOT: add1
  43. ; CHECK: ret
  44. define i64 @test5(i64 %a, i64 %b) nounwind ssp {
  45. entry:
  46. %ssub = tail call %0 @llvm.ssub.with.overflow.i64(i64 %a, i64 %b)
  47. %ssub.0 = extractvalue %0 %ssub, 0
  48. %sub1 = sub i64 %a, %b
  49. ret i64 %sub1
  50. }
  51. ; CHECK-LABEL: @test5(
  52. ; CHECK-NOT: sub1
  53. ; CHECK: ret
  54. define i64 @test6(i64 %a, i64 %b) nounwind ssp {
  55. entry:
  56. %smul = tail call %0 @llvm.smul.with.overflow.i64(i64 %a, i64 %b)
  57. %smul.0 = extractvalue %0 %smul, 0
  58. %mul1 = mul i64 %a, %b
  59. ret i64 %mul1
  60. }
  61. ; CHECK-LABEL: @test6(
  62. ; CHECK-NOT: mul1
  63. ; CHECK: ret
  64. declare void @exit(i32) noreturn
  65. declare %0 @llvm.uadd.with.overflow.i64(i64, i64) nounwind readnone
  66. declare %0 @llvm.usub.with.overflow.i64(i64, i64) nounwind readnone
  67. declare %0 @llvm.umul.with.overflow.i64(i64, i64) nounwind readnone
  68. declare %0 @llvm.sadd.with.overflow.i64(i64, i64) nounwind readnone
  69. declare %0 @llvm.ssub.with.overflow.i64(i64, i64) nounwind readnone
  70. declare %0 @llvm.smul.with.overflow.i64(i64, i64) nounwind readnone