call.ll 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. ; RUN: opt < %s -instsimplify -S | FileCheck %s
  2. declare {i8, i1} @llvm.uadd.with.overflow.i8(i8 %a, i8 %b)
  3. declare {i8, i1} @llvm.usub.with.overflow.i8(i8 %a, i8 %b)
  4. declare {i8, i1} @llvm.ssub.with.overflow.i8(i8 %a, i8 %b)
  5. declare {i8, i1} @llvm.umul.with.overflow.i8(i8 %a, i8 %b)
  6. define i1 @test_uadd1() {
  7. ; CHECK-LABEL: @test_uadd1(
  8. %x = call {i8, i1} @llvm.uadd.with.overflow.i8(i8 254, i8 3)
  9. %overflow = extractvalue {i8, i1} %x, 1
  10. ret i1 %overflow
  11. ; CHECK-NEXT: ret i1 true
  12. }
  13. define i8 @test_uadd2() {
  14. ; CHECK-LABEL: @test_uadd2(
  15. %x = call {i8, i1} @llvm.uadd.with.overflow.i8(i8 254, i8 44)
  16. %result = extractvalue {i8, i1} %x, 0
  17. ret i8 %result
  18. ; CHECK-NEXT: ret i8 42
  19. }
  20. define {i8, i1} @test_usub1(i8 %V) {
  21. ; CHECK-LABEL: @test_usub1(
  22. %x = call {i8, i1} @llvm.usub.with.overflow.i8(i8 %V, i8 %V)
  23. ret {i8, i1} %x
  24. ; CHECK-NEXT: ret { i8, i1 } zeroinitializer
  25. }
  26. define {i8, i1} @test_ssub1(i8 %V) {
  27. ; CHECK-LABEL: @test_ssub1(
  28. %x = call {i8, i1} @llvm.ssub.with.overflow.i8(i8 %V, i8 %V)
  29. ret {i8, i1} %x
  30. ; CHECK-NEXT: ret { i8, i1 } zeroinitializer
  31. }
  32. define {i8, i1} @test_umul1(i8 %V) {
  33. ; CHECK-LABEL: @test_umul1(
  34. %x = call {i8, i1} @llvm.umul.with.overflow.i8(i8 %V, i8 0)
  35. ret {i8, i1} %x
  36. ; CHECK-NEXT: ret { i8, i1 } zeroinitializer
  37. }
  38. declare i256 @llvm.cttz.i256(i256 %src, i1 %is_zero_undef)
  39. define i256 @test_cttz() {
  40. ; CHECK-LABEL: @test_cttz(
  41. %x = call i256 @llvm.cttz.i256(i256 10, i1 false)
  42. ret i256 %x
  43. ; CHECK-NEXT: ret i256 1
  44. }
  45. declare i256 @llvm.ctpop.i256(i256 %src)
  46. define i256 @test_ctpop() {
  47. ; CHECK-LABEL: @test_ctpop(
  48. %x = call i256 @llvm.ctpop.i256(i256 10)
  49. ret i256 %x
  50. ; CHECK-NEXT: ret i256 2
  51. }
  52. ; Test a non-intrinsic that we know about as a library call.
  53. declare float @fabs(float %x)
  54. define float @test_fabs_libcall() {
  55. ; CHECK-LABEL: @test_fabs_libcall(
  56. %x = call float @fabs(float -42.0)
  57. ; This is still a real function call, so instsimplify won't nuke it -- other
  58. ; passes have to do that.
  59. ; CHECK-NEXT: call float @fabs
  60. ret float %x
  61. ; CHECK-NEXT: ret float 4.2{{0+}}e+01
  62. }
  63. declare float @llvm.fabs.f32(float) nounwind readnone
  64. declare float @llvm.floor.f32(float) nounwind readnone
  65. declare float @llvm.ceil.f32(float) nounwind readnone
  66. declare float @llvm.trunc.f32(float) nounwind readnone
  67. declare float @llvm.rint.f32(float) nounwind readnone
  68. declare float @llvm.nearbyint.f32(float) nounwind readnone
  69. ; Test idempotent intrinsics
  70. define float @test_idempotence(float %a) {
  71. ; CHECK-LABEL: @test_idempotence(
  72. ; CHECK: fabs
  73. ; CHECK-NOT: fabs
  74. %a0 = call float @llvm.fabs.f32(float %a)
  75. %a1 = call float @llvm.fabs.f32(float %a0)
  76. ; CHECK: floor
  77. ; CHECK-NOT: floor
  78. %b0 = call float @llvm.floor.f32(float %a)
  79. %b1 = call float @llvm.floor.f32(float %b0)
  80. ; CHECK: ceil
  81. ; CHECK-NOT: ceil
  82. %c0 = call float @llvm.ceil.f32(float %a)
  83. %c1 = call float @llvm.ceil.f32(float %c0)
  84. ; CHECK: trunc
  85. ; CHECK-NOT: trunc
  86. %d0 = call float @llvm.trunc.f32(float %a)
  87. %d1 = call float @llvm.trunc.f32(float %d0)
  88. ; CHECK: rint
  89. ; CHECK-NOT: rint
  90. %e0 = call float @llvm.rint.f32(float %a)
  91. %e1 = call float @llvm.rint.f32(float %e0)
  92. ; CHECK: nearbyint
  93. ; CHECK-NOT: nearbyint
  94. %f0 = call float @llvm.nearbyint.f32(float %a)
  95. %f1 = call float @llvm.nearbyint.f32(float %f0)
  96. %r0 = fadd float %a1, %b1
  97. %r1 = fadd float %r0, %c1
  98. %r2 = fadd float %r1, %d1
  99. %r3 = fadd float %r2, %e1
  100. %r4 = fadd float %r3, %f1
  101. ret float %r4
  102. }
  103. define i8* @operator_new() {
  104. entry:
  105. %call = tail call noalias i8* @_Znwm(i64 8)
  106. %cmp = icmp eq i8* %call, null
  107. br i1 %cmp, label %cast.end, label %cast.notnull
  108. cast.notnull: ; preds = %entry
  109. %add.ptr = getelementptr inbounds i8, i8* %call, i64 4
  110. br label %cast.end
  111. cast.end: ; preds = %cast.notnull, %entry
  112. %cast.result = phi i8* [ %add.ptr, %cast.notnull ], [ null, %entry ]
  113. ret i8* %cast.result
  114. ; CHECK-LABEL: @operator_new
  115. ; CHECK: br i1 false, label %cast.end, label %cast.notnull
  116. }
  117. declare noalias i8* @_Znwm(i64)
  118. %"struct.std::nothrow_t" = type { i8 }
  119. @_ZSt7nothrow = external global %"struct.std::nothrow_t"
  120. define i8* @operator_new_nothrow_t() {
  121. entry:
  122. %call = tail call noalias i8* @_ZnamRKSt9nothrow_t(i64 8, %"struct.std::nothrow_t"* @_ZSt7nothrow)
  123. %cmp = icmp eq i8* %call, null
  124. br i1 %cmp, label %cast.end, label %cast.notnull
  125. cast.notnull: ; preds = %entry
  126. %add.ptr = getelementptr inbounds i8, i8* %call, i64 4
  127. br label %cast.end
  128. cast.end: ; preds = %cast.notnull, %entry
  129. %cast.result = phi i8* [ %add.ptr, %cast.notnull ], [ null, %entry ]
  130. ret i8* %cast.result
  131. ; CHECK-LABEL: @operator_new_nothrow_t
  132. ; CHECK: br i1 %cmp, label %cast.end, label %cast.notnull
  133. }
  134. declare i8* @_ZnamRKSt9nothrow_t(i64, %"struct.std::nothrow_t"*) nounwind
  135. define i8* @malloc_can_return_null() {
  136. entry:
  137. %call = tail call noalias i8* @malloc(i64 8)
  138. %cmp = icmp eq i8* %call, null
  139. br i1 %cmp, label %cast.end, label %cast.notnull
  140. cast.notnull: ; preds = %entry
  141. %add.ptr = getelementptr inbounds i8, i8* %call, i64 4
  142. br label %cast.end
  143. cast.end: ; preds = %cast.notnull, %entry
  144. %cast.result = phi i8* [ %add.ptr, %cast.notnull ], [ null, %entry ]
  145. ret i8* %cast.result
  146. ; CHECK-LABEL: @malloc_can_return_null
  147. ; CHECK: br i1 %cmp, label %cast.end, label %cast.notnull
  148. }
  149. declare noalias i8* @malloc(i64)