cxx11-initializer-array-new.cpp 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. // RUN: %clang_cc1 -triple x86_64-linux-gnu -std=c++11 %s -emit-llvm -o - | FileCheck %s
  2. // PR10878
  3. struct S { S(); S(int); ~S(); int n; };
  4. void *p = new S[2][3]{ { 1, 2, 3 }, { 4, 5, 6 } };
  5. // CHECK-LABEL: define
  6. // CHECK: %[[ALLOC:.*]] = call i8* @_Znam(i64 32)
  7. // CHECK: %[[COOKIE:.*]] = bitcast i8* %[[ALLOC]] to i64*
  8. // CHECK: store i64 6, i64* %[[COOKIE]]
  9. // CHECK: %[[START_AS_i8:.*]] = getelementptr inbounds i8, i8* %[[ALLOC]], i64 8
  10. // CHECK: %[[START_AS_S:.*]] = bitcast i8* %[[START_AS_i8]] to %[[S:.*]]*
  11. //
  12. // Explicit initializers:
  13. //
  14. // { 1, 2, 3 }
  15. //
  16. // CHECK: %[[S_0:.*]] = bitcast %[[S]]* %[[START_AS_S]] to [3 x %[[S]]]*
  17. //
  18. // CHECK: %[[S_0_0:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_0]], i64 0, i64 0
  19. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_0_0]], i32 1)
  20. // CHECK: %[[S_0_1:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_0_0]], i64 1
  21. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_0_1]], i32 2)
  22. // CHECK: %[[S_0_2:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_0_1]], i64 1
  23. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_0_2]], i32 3)
  24. //
  25. // { 4, 5, 6 }
  26. //
  27. // CHECK: %[[S_1:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_0]], i64 1
  28. //
  29. // CHECK: %[[S_1_0:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_1]], i64 0, i64 0
  30. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_1_0]], i32 4)
  31. // CHECK: %[[S_1_1:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_1_0]], i64 1
  32. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_1_1]], i32 5)
  33. // CHECK: %[[S_1_2:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_1_1]], i64 1
  34. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_1_2]], i32 6)
  35. //
  36. // CHECK-NOT: br i1
  37. // CHECK-NOT: call
  38. // CHECK: }
  39. int n;
  40. void *q = new S[n][3]{ { 1, 2, 3 }, { 4, 5, 6 } };
  41. // CHECK-LABEL: define
  42. //
  43. // CHECK: load i32, i32* @n
  44. // CHECK: call {{.*}} @llvm.umul.with.overflow.i64(i64 %[[N:.*]], i64 12)
  45. // CHECK: %[[ELTS:.*]] = mul i64 %[[N]], 3
  46. // CHECK: call {{.*}} @llvm.uadd.with.overflow.i64(i64 %{{.*}}, i64 8)
  47. // CHECK: %[[ALLOC:.*]] = call i8* @_Znam(i64 %{{.*}})
  48. //
  49. // CHECK: %[[COOKIE:.*]] = bitcast i8* %[[ALLOC]] to i64*
  50. // CHECK: store i64 %[[ELTS]], i64* %[[COOKIE]]
  51. // CHECK: %[[START_AS_i8:.*]] = getelementptr inbounds i8, i8* %[[ALLOC]], i64 8
  52. // CHECK: %[[START_AS_S:.*]] = bitcast i8* %[[START_AS_i8]] to %[[S]]*
  53. //
  54. // Explicit initializers:
  55. //
  56. // { 1, 2, 3 }
  57. //
  58. // CHECK: %[[S_0:.*]] = bitcast %[[S]]* %[[START_AS_S]] to [3 x %[[S]]]*
  59. //
  60. // CHECK: %[[S_0_0:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_0]], i64 0, i64 0
  61. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_0_0]], i32 1)
  62. // CHECK: %[[S_0_1:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_0_0]], i64 1
  63. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_0_1]], i32 2)
  64. // CHECK: %[[S_0_2:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_0_1]], i64 1
  65. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_0_2]], i32 3)
  66. //
  67. // { 4, 5, 6 }
  68. //
  69. // CHECK: %[[S_1:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_0]], i64 1
  70. //
  71. // CHECK: %[[S_1_0:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_1]], i64 0, i64 0
  72. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_1_0]], i32 4)
  73. // CHECK: %[[S_1_1:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_1_0]], i64 1
  74. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_1_1]], i32 5)
  75. // CHECK: %[[S_1_2:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_1_1]], i64 1
  76. // CHECK: call void @_ZN1SC1Ei(%[[S]]* noalias %[[S_1_2]], i32 6)
  77. //
  78. // And the rest.
  79. //
  80. // CHECK: %[[S_2:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_1]], i64 1
  81. // CHECK: %[[S_2_AS_S:.*]] = bitcast [3 x %[[S]]]* %[[S_2]] to %[[S]]*
  82. //
  83. // CHECK: %[[REST:.*]] = sub i64 %[[ELTS]], 6
  84. // CHECK: icmp eq i64 %[[REST]], 0
  85. // CHECK: br i1
  86. //
  87. // CHECK: %[[END:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_2_AS_S]], i64 %[[REST]]
  88. // CHECK: br label
  89. //
  90. // CHECK: %[[CUR:.*]] = phi %[[S]]* [ %[[S_2_AS_S]], {{.*}} ], [ %[[NEXT:.*]], {{.*}} ]
  91. // CHECK: call void @_ZN1SC1Ev(%[[S]]* noalias %[[CUR]])
  92. // CHECK: %[[NEXT]] = getelementptr inbounds %[[S]], %[[S]]* %[[CUR]], i64 1
  93. // CHECK: icmp eq %[[S]]* %[[NEXT]], %[[END]]
  94. // CHECK: br i1
  95. //
  96. // CHECK: }
  97. struct T { int a; };
  98. void *r = new T[n][3]{ { 1, 2, 3 }, { 4, 5, 6 } };
  99. // CHECK-LABEL: define
  100. //
  101. // CHECK: load i32, i32* @n
  102. // CHECK: call {{.*}} @llvm.umul.with.overflow.i64(i64 %[[N:.*]], i64 12)
  103. // CHECK: %[[ELTS:.*]] = mul i64 %[[N]], 3
  104. //
  105. // No cookie.
  106. // CHECK-NOT: @llvm.uadd.with.overflow
  107. //
  108. // CHECK: %[[ALLOC:.*]] = call i8* @_Znam(i64 %{{.*}})
  109. //
  110. // CHECK: %[[START_AS_T:.*]] = bitcast i8* %[[ALLOC]] to %[[T:.*]]*
  111. //
  112. // Explicit initializers:
  113. //
  114. // { 1, 2, 3 }
  115. //
  116. // CHECK: %[[T_0:.*]] = bitcast %[[T]]* %[[START_AS_T]] to [3 x %[[T]]]*
  117. //
  118. // CHECK: %[[T_0_0:.*]] = getelementptr inbounds [3 x %[[T]]], [3 x %[[T]]]* %[[T_0]], i64 0, i64 0
  119. // CHECK: %[[T_0_0_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_0]], i32 0, i32 0
  120. // CHECK: store i32 1, i32* %[[T_0_0_0]]
  121. // CHECK: %[[T_0_1:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_0]], i64 1
  122. // CHECK: %[[T_0_1_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_1]], i32 0, i32 0
  123. // CHECK: store i32 2, i32* %[[T_0_1_0]]
  124. // CHECK: %[[T_0_2:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_1]], i64 1
  125. // CHECK: %[[T_0_2_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_2]], i32 0, i32 0
  126. // CHECK: store i32 3, i32* %[[T_0_2_0]]
  127. //
  128. // { 4, 5, 6 }
  129. //
  130. // CHECK: %[[T_1:.*]] = getelementptr inbounds [3 x %[[T]]], [3 x %[[T]]]* %[[T_0]], i64 1
  131. //
  132. // CHECK: %[[T_1_0:.*]] = getelementptr inbounds [3 x %[[T]]], [3 x %[[T]]]* %[[T_1]], i64 0, i64 0
  133. // CHECK: %[[T_1_0_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_0]], i32 0, i32 0
  134. // CHECK: store i32 4, i32* %[[T_1_0_0]]
  135. // CHECK: %[[T_1_1:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_0]], i64 1
  136. // CHECK: %[[T_1_1_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_1]], i32 0, i32 0
  137. // CHECK: store i32 5, i32* %[[T_1_1_0]]
  138. // CHECK: %[[T_1_2:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_1]], i64 1
  139. // CHECK: %[[T_1_2_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_2]], i32 0, i32 0
  140. // CHECK: store i32 6, i32* %[[T_1_2_0]]
  141. //
  142. // And the rest gets memset to 0.
  143. //
  144. // CHECK: %[[T_2:.*]] = getelementptr inbounds [3 x %[[T]]], [3 x %[[T]]]* %[[T_1]], i64 1
  145. // CHECK: %[[T_2_AS_T:.*]] = bitcast [3 x %[[T]]]* %[[T_2]] to %[[T]]*
  146. //
  147. // CHECK: %[[SIZE:.*]] = sub i64 %{{.*}}, 24
  148. // CHECK: %[[REST:.*]] = bitcast %[[T]]* %[[T_2_AS_T]] to i8*
  149. // CHECK: call void @llvm.memset.p0i8.i64(i8* align 4 %[[REST]], i8 0, i64 %[[SIZE]], i1 false)
  150. //
  151. // CHECK: }