addrspacecast.ll 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. ; RUN: opt -instcombine -S < %s | FileCheck %s
  2. target datalayout = "e-p:64:64:64-p1:32:32:32-p2:16:16:16-n8:16:32:64"
  3. declare void @llvm.memcpy.p0i8.p0i8.i32(i8*, i8*, i32, i32, i1) nounwind
  4. declare void @llvm.memcpy.p0i8.p1i8.i32(i8*, i8 addrspace(1)*, i32, i32, i1) nounwind
  5. declare void @llvm.memcpy.p0i8.p2i8.i32(i8*, i8 addrspace(2)*, i32, i32, i1) nounwind
  6. define i32* @combine_redundant_addrspacecast(i32 addrspace(1)* %x) nounwind {
  7. ; CHECK-LABEL: @combine_redundant_addrspacecast(
  8. ; CHECK: addrspacecast i32 addrspace(1)* %x to i32*
  9. ; CHECK-NEXT: ret
  10. %y = addrspacecast i32 addrspace(1)* %x to i32 addrspace(3)*
  11. %z = addrspacecast i32 addrspace(3)* %y to i32*
  12. ret i32* %z
  13. }
  14. define <4 x i32*> @combine_redundant_addrspacecast_vector(<4 x i32 addrspace(1)*> %x) nounwind {
  15. ; CHECK-LABEL: @combine_redundant_addrspacecast_vector(
  16. ; CHECK: addrspacecast <4 x i32 addrspace(1)*> %x to <4 x i32*>
  17. ; CHECK-NEXT: ret
  18. %y = addrspacecast <4 x i32 addrspace(1)*> %x to <4 x i32 addrspace(3)*>
  19. %z = addrspacecast <4 x i32 addrspace(3)*> %y to <4 x i32*>
  20. ret <4 x i32*> %z
  21. }
  22. define float* @combine_redundant_addrspacecast_types(i32 addrspace(1)* %x) nounwind {
  23. ; CHECK-LABEL: @combine_redundant_addrspacecast_types(
  24. ; CHECK-NEXT: bitcast i32 addrspace(1)* %x to float addrspace(1)*
  25. ; CHECK-NEXT: addrspacecast float addrspace(1)* %1 to float*
  26. ; CHECK-NEXT: ret
  27. %y = addrspacecast i32 addrspace(1)* %x to i32 addrspace(3)*
  28. %z = addrspacecast i32 addrspace(3)* %y to float*
  29. ret float* %z
  30. }
  31. define <4 x float*> @combine_redundant_addrspacecast_types_vector(<4 x i32 addrspace(1)*> %x) nounwind {
  32. ; CHECK-LABEL: @combine_redundant_addrspacecast_types_vector(
  33. ; CHECK-NEXT: bitcast <4 x i32 addrspace(1)*> %x to <4 x float addrspace(1)*>
  34. ; CHECK-NEXT: addrspacecast <4 x float addrspace(1)*> %1 to <4 x float*>
  35. ; CHECK-NEXT: ret
  36. %y = addrspacecast <4 x i32 addrspace(1)*> %x to <4 x i32 addrspace(3)*>
  37. %z = addrspacecast <4 x i32 addrspace(3)*> %y to <4 x float*>
  38. ret <4 x float*> %z
  39. }
  40. define float addrspace(2)* @combine_addrspacecast_bitcast_1(i32 addrspace(1)* %x) nounwind {
  41. ; CHECK-LABEL: @combine_addrspacecast_bitcast_1(
  42. ; CHECK-NEXT: bitcast i32 addrspace(1)* %x to float addrspace(1)*
  43. ; CHECK-NEXT: addrspacecast float addrspace(1)* %1 to float addrspace(2)*
  44. ; CHECK-NEXT: ret
  45. %y = addrspacecast i32 addrspace(1)* %x to i32 addrspace(2)*
  46. %z = bitcast i32 addrspace(2)* %y to float addrspace(2)*
  47. ret float addrspace(2)* %z
  48. }
  49. define i32 addrspace(2)* @combine_addrspacecast_bitcast_2(i32 addrspace(1)* %x) nounwind {
  50. ; CHECK-LABEL: @combine_addrspacecast_bitcast_2(
  51. ; CHECK: addrspacecast i32 addrspace(1)* %x to i32 addrspace(2)*
  52. ; CHECK-NEXT: ret
  53. %y = addrspacecast i32 addrspace(1)* %x to float addrspace(2)*
  54. %z = bitcast float addrspace(2)* %y to i32 addrspace(2)*
  55. ret i32 addrspace(2)* %z
  56. }
  57. define i32 addrspace(2)* @combine_bitcast_addrspacecast_1(i32 addrspace(1)* %x) nounwind {
  58. ; CHECK-LABEL: @combine_bitcast_addrspacecast_1(
  59. ; CHECK: addrspacecast i32 addrspace(1)* %x to i32 addrspace(2)*
  60. ; CHECK-NEXT: ret
  61. %y = bitcast i32 addrspace(1)* %x to i8 addrspace(1)*
  62. %z = addrspacecast i8 addrspace(1)* %y to i32 addrspace(2)*
  63. ret i32 addrspace(2)* %z
  64. }
  65. define float addrspace(2)* @combine_bitcast_addrspacecast_2(i32 addrspace(1)* %x) nounwind {
  66. ; CHECK-LABEL: @combine_bitcast_addrspacecast_2(
  67. ; CHECK: bitcast i32 addrspace(1)* %x to float addrspace(1)*
  68. ; CHECK: addrspacecast float addrspace(1)* %1 to float addrspace(2)*
  69. ; CHECK-NEXT: ret
  70. %y = bitcast i32 addrspace(1)* %x to i8 addrspace(1)*
  71. %z = addrspacecast i8 addrspace(1)* %y to float addrspace(2)*
  72. ret float addrspace(2)* %z
  73. }
  74. define float addrspace(2)* @combine_addrspacecast_types(i32 addrspace(1)* %x) nounwind {
  75. ; CHECK-LABEL: @combine_addrspacecast_types(
  76. ; CHECK-NEXT: bitcast i32 addrspace(1)* %x to float addrspace(1)*
  77. ; CHECK-NEXT: addrspacecast float addrspace(1)* %1 to float addrspace(2)*
  78. ; CHECK-NEXT: ret
  79. %y = addrspacecast i32 addrspace(1)* %x to float addrspace(2)*
  80. ret float addrspace(2)* %y
  81. }
  82. define <4 x float addrspace(2)*> @combine_addrspacecast_types_vector(<4 x i32 addrspace(1)*> %x) nounwind {
  83. ; CHECK-LABEL: @combine_addrspacecast_types_vector(
  84. ; CHECK-NEXT: bitcast <4 x i32 addrspace(1)*> %x to <4 x float addrspace(1)*>
  85. ; CHECK-NEXT: addrspacecast <4 x float addrspace(1)*> %1 to <4 x float addrspace(2)*>
  86. ; CHECK-NEXT: ret
  87. %y = addrspacecast <4 x i32 addrspace(1)*> %x to <4 x float addrspace(2)*>
  88. ret <4 x float addrspace(2)*> %y
  89. }
  90. define i32 @canonicalize_addrspacecast([16 x i32] addrspace(1)* %arr) {
  91. ; CHECK-LABEL: @canonicalize_addrspacecast(
  92. ; CHECK-NEXT: getelementptr inbounds [16 x i32], [16 x i32] addrspace(1)* %arr, i32 0, i32 0
  93. ; CHECK-NEXT: addrspacecast i32 addrspace(1)* %{{[a-zA-Z0-9]+}} to i32*
  94. ; CHECK-NEXT: load i32, i32*
  95. ; CHECK-NEXT: ret i32
  96. %p = addrspacecast [16 x i32] addrspace(1)* %arr to i32*
  97. %v = load i32, i32* %p
  98. ret i32 %v
  99. }
  100. @const_array = addrspace(2) constant [60 x i8] [i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22,
  101. i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22,
  102. i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22,
  103. i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22,
  104. i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22, i8 2, i8 9, i8 4, i8 22 ]
  105. declare void @foo(i8*) nounwind
  106. ; A copy from a constant addrspacecast'ed global
  107. ; CHECK-LABEL: @memcpy_addrspacecast(
  108. ; CHECK-NOT: call void @llvm.memcpy
  109. define i32 @memcpy_addrspacecast() nounwind {
  110. entry:
  111. %alloca = alloca i8, i32 48
  112. call void @llvm.memcpy.p0i8.p1i8.i32(i8* %alloca, i8 addrspace(1)* addrspacecast (i8 addrspace(2)* getelementptr inbounds ([60 x i8], [60 x i8] addrspace(2)* @const_array, i16 0, i16 4) to i8 addrspace(1)*), i32 48, i32 4, i1 false) nounwind
  113. br label %loop.body
  114. loop.body:
  115. %i = phi i32 [ 0, %entry ], [ %i.inc, %loop.body ]
  116. %sum = phi i32 [ 0, %entry ], [ %sum.inc, %loop.body]
  117. %ptr = getelementptr i8, i8* %alloca, i32 %i
  118. %load = load i8, i8* %ptr
  119. %ext = zext i8 %load to i32
  120. %sum.inc = add i32 %sum, %ext
  121. %i.inc = add i32 %i, 1
  122. %cmp = icmp ne i32 %i, 48
  123. br i1 %cmp, label %loop.body, label %end
  124. end:
  125. ret i32 %sum.inc
  126. }