1 // RUN: %clang_cc1 -std=c++11 -triple x86_64-none-linux-gnu -emit-llvm -o - %s | FileCheck %s
2 
3 namespace std {
4   typedef decltype(sizeof(int)) size_t;
5 
6   // libc++'s implementation
7   template <class _E>
8   class initializer_list
9   {
10     const _E* __begin_;
11     size_t    __size_;
12 
13     initializer_list(const _E* __b, size_t __s)
14       : __begin_(__b),
15         __size_(__s)
16     {}
17 
18   public:
19     typedef _E        value_type;
20     typedef const _E& reference;
21     typedef const _E& const_reference;
22     typedef size_t    size_type;
23 
24     typedef const _E* iterator;
25     typedef const _E* const_iterator;
26 
27     initializer_list() : __begin_(nullptr), __size_(0) {}
28 
29     size_t    size()  const {return __size_;}
30     const _E* begin() const {return __begin_;}
31     const _E* end()   const {return __begin_ + __size_;}
32   };
33 }
34 
35 struct destroyme1 {
36   ~destroyme1();
37 };
38 struct destroyme2 {
39   ~destroyme2();
40 };
41 struct witharg1 {
42   witharg1(const destroyme1&);
43   ~witharg1();
44 };
45 struct wantslist1 {
46   wantslist1(std::initializer_list<destroyme1>);
47   ~wantslist1();
48 };
49 
50 // CHECK: @_ZGR15globalInitList1_ = internal constant [3 x i32] [i32 1, i32 2, i32 3]
51 // CHECK: @globalInitList1 = global %{{[^ ]+}} { i32* getelementptr inbounds ([3 x i32], [3 x i32]* @_ZGR15globalInitList1_, i32 0, i32 0), i{{32|64}} 3 }
52 std::initializer_list<int> globalInitList1 = {1, 2, 3};
53 
54 namespace thread_local_global_array {
55   // FIXME: We should be able to constant-evaluate this even though the
56   // initializer is not a constant expression (pointers to thread_local
57   // objects aren't really a problem).
58   //
59   // CHECK: @_ZN25thread_local_global_array1xE = thread_local global
60   // CHECK: @_ZGRN25thread_local_global_array1xE_ = internal thread_local constant [4 x i32] [i32 1, i32 2, i32 3, i32 4]
61   std::initializer_list<int> thread_local x = { 1, 2, 3, 4 };
62 }
63 
64 // CHECK: @globalInitList2 = global %{{[^ ]+}} zeroinitializer
65 // CHECK: @_ZGR15globalInitList2_ = internal global [2 x %[[WITHARG:[^ ]*]]] zeroinitializer
66 
67 // CHECK: @_ZN15partly_constant1kE = global i32 0, align 4
68 // CHECK: @_ZN15partly_constant2ilE = global {{.*}} null, align 8
69 // CHECK: @[[PARTLY_CONSTANT_OUTER:_ZGRN15partly_constant2ilE.*]] = internal global {{.*}} zeroinitializer, align 8
70 // CHECK: @[[PARTLY_CONSTANT_INNER:_ZGRN15partly_constant2ilE.*]] = internal global [3 x {{.*}}] zeroinitializer, align 8
71 // CHECK: @[[PARTLY_CONSTANT_FIRST:_ZGRN15partly_constant2ilE.*]] = internal constant [3 x i32] [i32 1, i32 2, i32 3], align 4
72 // CHECK: @[[PARTLY_CONSTANT_SECOND:_ZGRN15partly_constant2ilE.*]] = internal global [2 x i32] zeroinitializer, align 4
73 // CHECK: @[[PARTLY_CONSTANT_THIRD:_ZGRN15partly_constant2ilE.*]] = internal constant [4 x i32] [i32 5, i32 6, i32 7, i32 8], align 4
74 
75 // CHECK: @[[REFTMP1:.*]] = private constant [2 x i32] [i32 42, i32 43], align 4
76 // CHECK: @[[REFTMP2:.*]] = private constant [3 x %{{.*}}] [%{{.*}} { i32 1 }, %{{.*}} { i32 2 }, %{{.*}} { i32 3 }], align 4
77 
78 // CHECK: appending global
79 
80 
81 // thread_local initializer:
82 // CHECK-LABEL: define internal void
83 // CHECK: store i32* getelementptr inbounds ([4 x i32], [4 x i32]* @_ZGRN25thread_local_global_array1xE_, i64 0, i64 0),
84 // CHECK:       i32** getelementptr inbounds ({{.*}}, {{.*}}* @_ZN25thread_local_global_array1xE, i32 0, i32 0), align 8
85 // CHECK: store i64 4, i64* getelementptr inbounds ({{.*}}, {{.*}}* @_ZN25thread_local_global_array1xE, i32 0, i32 1), align 8
86 
87 
88 // CHECK-LABEL: define internal void
89 // CHECK: call void @_ZN8witharg1C1ERK10destroyme1(%[[WITHARG]]* getelementptr inbounds ([2 x %[[WITHARG]]], [2 x %[[WITHARG]]]* @_ZGR15globalInitList2_, i{{32|64}} 0, i{{32|64}} 0
90 // CHECK: call void @_ZN8witharg1C1ERK10destroyme1(%[[WITHARG]]* getelementptr inbounds ([2 x %[[WITHARG]]], [2 x %[[WITHARG]]]* @_ZGR15globalInitList2_, i{{32|64}} 0, i{{32|64}} 1
91 // CHECK: __cxa_atexit
92 // CHECK: store %[[WITHARG]]* getelementptr inbounds ([2 x %[[WITHARG]]], [2 x %[[WITHARG]]]* @_ZGR15globalInitList2_, i64 0, i64 0),
93 // CHECK:       %[[WITHARG]]** getelementptr inbounds (%{{.*}}, %{{.*}}* @globalInitList2, i32 0, i32 0), align 8
94 // CHECK: store i64 2, i64* getelementptr inbounds (%{{.*}}, %{{.*}}* @globalInitList2, i32 0, i32 1), align 8
95 // CHECK: call void @_ZN10destroyme1D1Ev
96 // CHECK: call void @_ZN10destroyme1D1Ev
97 std::initializer_list<witharg1> globalInitList2 = {
98   witharg1(destroyme1()), witharg1(destroyme1())
99 };
100 
101 void fn1(int i) {
102   // CHECK-LABEL: define void @_Z3fn1i
103   // temporary array
104   // CHECK: [[array:%[^ ]+]] = alloca [3 x i32]
105   // CHECK: getelementptr inbounds [3 x i32], [3 x i32]* [[array]], i{{32|64}} 0
106   // CHECK-NEXT: store i32 1, i32*
107   // CHECK-NEXT: getelementptr
108   // CHECK-NEXT: store
109   // CHECK-NEXT: getelementptr
110   // CHECK-NEXT: load
111   // CHECK-NEXT: store
112   // init the list
113   // CHECK-NEXT: getelementptr
114   // CHECK-NEXT: getelementptr inbounds [3 x i32], [3 x i32]*
115   // CHECK-NEXT: store i32*
116   // CHECK-NEXT: getelementptr
117   // CHECK-NEXT: store i{{32|64}} 3
118   std::initializer_list<int> intlist{1, 2, i};
119 }
120 
121 void fn2() {
122   // CHECK-LABEL: define void @_Z3fn2v
123   void target(std::initializer_list<destroyme1>);
124   // objects should be destroyed before dm2, after call returns
125   // CHECK: call void @_Z6targetSt16initializer_listI10destroyme1E
126   target({ destroyme1(), destroyme1() });
127   // CHECK: call void @_ZN10destroyme1D1Ev
128   destroyme2 dm2;
129   // CHECK: call void @_ZN10destroyme2D1Ev
130 }
131 
132 void fn3() {
133   // CHECK-LABEL: define void @_Z3fn3v
134   // objects should be destroyed after dm2
135   auto list = { destroyme1(), destroyme1() };
136   destroyme2 dm2;
137   // CHECK: call void @_ZN10destroyme2D1Ev
138   // CHECK: call void @_ZN10destroyme1D1Ev
139 }
140 
141 void fn4() {
142   // CHECK-LABEL: define void @_Z3fn4v
143   void target(std::initializer_list<witharg1>);
144   // objects should be destroyed before dm2, after call returns
145   // CHECK: call void @_ZN8witharg1C1ERK10destroyme1
146   // CHECK: call void @_Z6targetSt16initializer_listI8witharg1E
147   target({ witharg1(destroyme1()), witharg1(destroyme1()) });
148   // CHECK: call void @_ZN8witharg1D1Ev
149   // CHECK: call void @_ZN10destroyme1D1Ev
150   destroyme2 dm2;
151   // CHECK: call void @_ZN10destroyme2D1Ev
152 }
153 
154 void fn5() {
155   // CHECK-LABEL: define void @_Z3fn5v
156   // temps should be destroyed before dm2
157   // objects should be destroyed after dm2
158   // CHECK: call void @_ZN8witharg1C1ERK10destroyme1
159   auto list = { witharg1(destroyme1()), witharg1(destroyme1()) };
160   // CHECK: call void @_ZN10destroyme1D1Ev
161   destroyme2 dm2;
162   // CHECK: call void @_ZN10destroyme2D1Ev
163   // CHECK: call void @_ZN8witharg1D1Ev
164 }
165 
166 void fn6() {
167   // CHECK-LABEL: define void @_Z3fn6v
168   void target(const wantslist1&);
169   // objects should be destroyed before dm2, after call returns
170   // CHECK: call void @_ZN10wantslist1C1ESt16initializer_listI10destroyme1E
171   // CHECK: call void @_Z6targetRK10wantslist1
172   target({ destroyme1(), destroyme1() });
173   // CHECK: call void @_ZN10wantslist1D1Ev
174   // CHECK: call void @_ZN10destroyme1D1Ev
175   destroyme2 dm2;
176   // CHECK: call void @_ZN10destroyme2D1Ev
177 }
178 
179 void fn7() {
180   // CHECK-LABEL: define void @_Z3fn7v
181   // temps should be destroyed before dm2
182   // object should be destroyed after dm2
183   // CHECK: call void @_ZN10wantslist1C1ESt16initializer_listI10destroyme1E
184   wantslist1 wl = { destroyme1(), destroyme1() };
185   // CHECK: call void @_ZN10destroyme1D1Ev
186   destroyme2 dm2;
187   // CHECK: call void @_ZN10destroyme2D1Ev
188   // CHECK: call void @_ZN10wantslist1D1Ev
189 }
190 
191 void fn8() {
192   // CHECK-LABEL: define void @_Z3fn8v
193   void target(std::initializer_list<std::initializer_list<destroyme1>>);
194   // objects should be destroyed before dm2, after call returns
195   // CHECK: call void @_Z6targetSt16initializer_listIS_I10destroyme1EE
196   std::initializer_list<destroyme1> inner;
197   target({ inner, { destroyme1() } });
198   // CHECK: call void @_ZN10destroyme1D1Ev
199   // Only one destroy loop, since only one inner init list is directly inited.
200   // CHECK-NOT: call void @_ZN10destroyme1D1Ev
201   destroyme2 dm2;
202   // CHECK: call void @_ZN10destroyme2D1Ev
203 }
204 
205 void fn9() {
206   // CHECK-LABEL: define void @_Z3fn9v
207   // objects should be destroyed after dm2
208   std::initializer_list<destroyme1> inner;
209   std::initializer_list<std::initializer_list<destroyme1>> list =
210       { inner, { destroyme1() } };
211   destroyme2 dm2;
212   // CHECK: call void @_ZN10destroyme2D1Ev
213   // CHECK: call void @_ZN10destroyme1D1Ev
214   // Only one destroy loop, since only one inner init list is directly inited.
215   // CHECK-NOT: call void @_ZN10destroyme1D1Ev
216   // CHECK: ret void
217 }
218 
219 struct haslist1 {
220   std::initializer_list<int> il;
221   haslist1(int i);
222 };
223 
224 // CHECK-LABEL: define void @_ZN8haslist1C2Ei
225 haslist1::haslist1(int i)
226 // CHECK: alloca [3 x i32]
227 // CHECK: store i32 %
228 // CHECK: store i32 2
229 // CHECK: store i32 3
230   : il{i, 2, 3}
231 {
232   destroyme2 dm2;
233 }
234 
235 struct haslist2 {
236   std::initializer_list<destroyme1> il;
237   haslist2();
238 };
239 
240 // CHECK-LABEL: define void @_ZN8haslist2C2Ev
241 haslist2::haslist2()
242   : il{destroyme1(), destroyme1()}
243 {
244   destroyme2 dm2;
245   // CHECK: call void @_ZN10destroyme2D1Ev
246   // CHECK: call void @_ZN10destroyme1D1Ev
247 }
248 
249 void fn10(int i) {
250   // CHECK-LABEL: define void @_Z4fn10i
251   // CHECK: alloca [3 x i32]
252   // CHECK: call i8* @_Znw{{[jm]}}
253   // CHECK: store i32 %
254   // CHECK: store i32 2
255   // CHECK: store i32 3
256   // CHECK: store i32*
257   (void) new std::initializer_list<int> {i, 2, 3};
258 }
259 
260 void fn11() {
261   // CHECK-LABEL: define void @_Z4fn11v
262   (void) new std::initializer_list<destroyme1> {destroyme1(), destroyme1()};
263   // CHECK: call void @_ZN10destroyme1D1Ev
264   destroyme2 dm2;
265   // CHECK: call void @_ZN10destroyme2D1Ev
266 }
267 
268 namespace PR12178 {
269   struct string {
270     string(int);
271     ~string();
272   };
273 
274   struct pair {
275     string a;
276     int b;
277   };
278 
279   struct map {
280     map(std::initializer_list<pair>);
281   };
282 
283   map m{ {1, 2}, {3, 4} };
284 }
285 
286 namespace rdar13325066 {
287   struct X { ~X(); };
288 
289   // CHECK-LABEL: define void @_ZN12rdar133250664loopERNS_1XES1_
290   void loop(X &x1, X &x2) {
291     // CHECK: br label
292     // CHECK: br i1
293     // CHECK: br label
294     // CHECK: call void @_ZN12rdar133250661XD1Ev
295     // CHECK: br label
296     // CHECK: br label
297     // CHECK: call void @_ZN12rdar133250661XD1Ev
298     // CHECK: br i1
299     // CHECK: br label
300     // CHECK: ret void
301     for (X x : { x1, x2 }) { }
302   }
303 }
304 
305 namespace dtors {
306   struct S {
307     S();
308     ~S();
309   };
310   void z();
311 
312   // CHECK-LABEL: define void @_ZN5dtors1fEv(
313   void f() {
314     // CHECK: call void @_ZN5dtors1SC1Ev(
315     // CHECK: call void @_ZN5dtors1SC1Ev(
316     std::initializer_list<S>{ S(), S() };
317 
318     // Destruction loop for underlying array.
319     // CHECK: br label
320     // CHECK: call void @_ZN5dtors1SD1Ev(
321     // CHECK: br i1
322 
323     // CHECK: call void @_ZN5dtors1zEv(
324     z();
325 
326     // CHECK-NOT: call void @_ZN5dtors1SD1Ev(
327   }
328 
329   // CHECK-LABEL: define void @_ZN5dtors1gEv(
330   void g() {
331     // CHECK: call void @_ZN5dtors1SC1Ev(
332     // CHECK: call void @_ZN5dtors1SC1Ev(
333     auto x = std::initializer_list<S>{ S(), S() };
334 
335     // Destruction loop for underlying array.
336     // CHECK: br label
337     // CHECK: call void @_ZN5dtors1SD1Ev(
338     // CHECK: br i1
339 
340     // CHECK: call void @_ZN5dtors1zEv(
341     z();
342 
343     // CHECK-NOT: call void @_ZN5dtors1SD1Ev(
344   }
345 
346   // CHECK-LABEL: define void @_ZN5dtors1hEv(
347   void h() {
348     // CHECK: call void @_ZN5dtors1SC1Ev(
349     // CHECK: call void @_ZN5dtors1SC1Ev(
350     std::initializer_list<S> x = { S(), S() };
351 
352     // CHECK-NOT: call void @_ZN5dtors1SD1Ev(
353 
354     // CHECK: call void @_ZN5dtors1zEv(
355     z();
356 
357     // Destruction loop for underlying array.
358     // CHECK: br label
359     // CHECK: call void @_ZN5dtors1SD1Ev(
360     // CHECK: br i1
361   }
362 }
363 
364 namespace partly_constant {
365   int k;
366   std::initializer_list<std::initializer_list<int>> &&il = { { 1, 2, 3 }, { 4, k }, { 5, 6, 7, 8 } };
367   // First init list.
368   // CHECK-NOT: @[[PARTLY_CONSTANT_FIRST]],
369   // CHECK: store i32* getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_FIRST]], i64 0, i64 0),
370   // CHECK:       i32** getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_INNER]], i64 0, i64 0, i32 0)
371   // CHECK: store i64 3, i64* getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_INNER]], i64 0, i64 0, i32 1)
372   // CHECK-NOT: @[[PARTLY_CONSTANT_FIRST]],
373   //
374   // Second init list array (non-constant).
375   // CHECK: store i32 4, i32* getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_SECOND]], i64 0, i64 0)
376   // CHECK: load i32, i32* @_ZN15partly_constant1kE
377   // CHECK: store i32 {{.*}}, i32* getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_SECOND]], i64 0, i64 1)
378   //
379   // Second init list.
380   // CHECK: store i32* getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_SECOND]], i64 0, i64 0),
381   // CHECK:       i32** getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_INNER]], i64 0, i64 1, i32 0)
382   // CHECK: store i64 2, i64* getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_INNER]], i64 0, i64 1, i32 1)
383   //
384   // Third init list.
385   // CHECK-NOT: @[[PARTLY_CONSTANT_THIRD]],
386   // CHECK: store i32* getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_THIRD]], i64 0, i64 0),
387   // CHECK:       i32** getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_INNER]], i64 0, i64 2, i32 0)
388   // CHECK: store i64 4, i64* getelementptr inbounds ({{.*}}, {{.*}}* @_ZGRN15partly_constant2ilE4_, i64 0, i64 2, i32 1)
389   // CHECK-NOT: @[[PARTLY_CONSTANT_THIRD]],
390   //
391   // Outer init list.
392   // CHECK: store {{.*}}* getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_INNER]], i64 0, i64 0),
393   // CHECK:       {{.*}}** getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_OUTER]], i32 0, i32 0)
394   // CHECK: store i64 3, i64* getelementptr inbounds ({{.*}}, {{.*}}* @[[PARTLY_CONSTANT_OUTER]], i32 0, i32 1)
395   //
396   // 'il' reference.
397   // CHECK: store {{.*}}* @[[PARTLY_CONSTANT_OUTER]], {{.*}}** @_ZN15partly_constant2ilE, align 8
398 }
399 
400 namespace nested {
401   struct A { A(); ~A(); };
402   struct B { const A &a; ~B(); };
403   struct C { std::initializer_list<B> b; ~C(); };
404   void f();
405   // CHECK-LABEL: define void @_ZN6nested1gEv(
406   void g() {
407     // CHECK: call void @_ZN6nested1AC1Ev(
408     // CHECK-NOT: call
409     // CHECK: call void @_ZN6nested1AC1Ev(
410     // CHECK-NOT: call
411     const C &c { { { A() }, { A() } } };
412 
413     // CHECK: call void @_ZN6nested1fEv(
414     // CHECK-NOT: call
415     f();
416 
417     // CHECK: call void @_ZN6nested1CD1Ev(
418     // CHECK-NOT: call
419 
420     // Destroy B[2] array.
421     // FIXME: This isn't technically correct: reverse construction order would
422     // destroy the second B then the second A then the first B then the first A.
423     // CHECK: call void @_ZN6nested1BD1Ev(
424     // CHECK-NOT: call
425     // CHECK: br
426 
427     // CHECK-NOT: call
428     // CHECK: call void @_ZN6nested1AD1Ev(
429     // CHECK-NOT: call
430     // CHECK: call void @_ZN6nested1AD1Ev(
431     // CHECK-NOT: call
432     // CHECK: }
433   }
434 }
435 
436 namespace DR1070 {
437   struct A {
438     A(std::initializer_list<int>);
439   };
440   struct B {
441     int i;
442     A a;
443   };
444   B b = {1};
445   struct C {
446     std::initializer_list<int> a;
447     B b;
448     std::initializer_list<double> c;
449   };
450   C c = {};
451 }
452 
453 namespace ArrayOfInitList {
454   struct S {
455     S(std::initializer_list<int>);
456   };
457   S x[1] = {};
458 }
459 
460 namespace PR20445 {
461   struct vector { vector(std::initializer_list<int>); };
462   struct MyClass { explicit MyClass(const vector &v); };
463   template<int x> void f() { new MyClass({42, 43}); }
464   template void f<0>();
465   // CHECK-LABEL: define {{.*}} @_ZN7PR204451fILi0EEEvv(
466   // CHECK: store i32* getelementptr inbounds ([2 x i32], [2 x i32]* @[[REFTMP1]], i64 0, i64 0)
467   // CHECK: call void @_ZN7PR204456vectorC1ESt16initializer_listIiE(
468   // CHECK: call void @_ZN7PR204457MyClassC1ERKNS_6vectorE(
469 }
470 
471 namespace ConstExpr {
472   class C {
473     int x;
474   public:
475     constexpr C(int x) : x(x) {}
476   };
477   void f(std::initializer_list<C>);
478   void g() {
479 // CHECK-LABEL: _ZN9ConstExpr1gEv
480 // CHECK: store %"class.ConstExpr::C"* getelementptr inbounds ([3 x %"class.ConstExpr::C"], [3 x %"class.ConstExpr::C"]* @[[REFTMP2]], i64 0, i64 0)
481 // CHECK: call void @_ZN9ConstExpr1fESt16initializer_listINS_1CEE
482     f({C(1), C(2), C(3)});
483   }
484 }
485 
486 namespace B19773010 {
487   template <class T1, class T2> struct pair {
488     T1 first;
489     T2 second;
490     constexpr pair() : first(), second() {}
491     constexpr pair(T1 a, T2 b) : first(a), second(b) {}
492   };
493 
494   enum E { ENUM_CONSTANT };
495   struct testcase {
496     testcase(std::initializer_list<pair<const char *, E>>);
497   };
498   void f1() {
499     // CHECK-LABEL: @_ZN9B197730102f1Ev
500     testcase a{{"", ENUM_CONSTANT}};
501     // CHECK: store %"struct.B19773010::pair"* getelementptr inbounds ([1 x %"struct.B19773010::pair"], [1 x %"struct.B19773010::pair"]* bitcast ([1 x { i8*, i32 }]* @.ref.tmp{{.*}} to [1 x %"struct.B19773010::pair"]*), i64 0, i64 0), %"struct.B19773010::pair"** %{{.*}}, align 8
502   }
503   void f2() {
504     // CHECK-LABEL: @_ZN9B197730102f2Ev
505     // CHECK: store %"struct.B19773010::pair"* getelementptr inbounds ([1 x %"struct.B19773010::pair"], [1 x %"struct.B19773010::pair"]* bitcast ([1 x { i8*, i32 }]* @_ZGRZN9B197730102f2EvE1p_ to [1 x %"struct.B19773010::pair"]*), i64 0, i64 0), %"struct.B19773010::pair"** getelementptr inbounds ([2 x %"class.std::initializer_list.10"], [2 x %"class.std::initializer_list.10"]* @_ZZN9B197730102f2EvE1p, i64 0, i64 1, i32 0), align 16
506     static std::initializer_list<pair<const char *, E>> a, p[2] =
507         {a, {{"", ENUM_CONSTANT}}};
508   }
509 
510   void PR22940_helper(const pair<void*, int>&) { }
511   void PR22940() {
512     // CHECK-LABEL: @_ZN9B197730107PR22940Ev
513     // CHECK: call {{.*}} @_ZN9B197730104pairIPviEC{{.}}Ev(
514     // CHECK: call {{.*}} @_ZN9B1977301014PR22940_helperERKNS_4pairIPviEE(
515     PR22940_helper(pair<void*, int>());
516   }
517 }
518