1 // RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp -x c++ -emit-llvm %s -o - -femit-all-decls | FileCheck %s 2 // RUN: %clang_cc1 -fopenmp -x c++ -triple x86_64-apple-darwin10 -emit-pch -o %t %s 3 // RUN: %clang_cc1 -fopenmp -x c++ -triple x86_64-apple-darwin10 -include-pch %t -verify %s -emit-llvm -o - -femit-all-decls | FileCheck %s 4 5 // RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp-simd -x c++ -emit-llvm %s -o - -femit-all-decls | FileCheck --check-prefix SIMD-ONLY0 %s 6 // RUN: %clang_cc1 -fopenmp-simd -x c++ -triple x86_64-apple-darwin10 -emit-pch -o %t %s 7 // RUN: %clang_cc1 -fopenmp-simd -x c++ -triple x86_64-apple-darwin10 -include-pch %t -verify %s -emit-llvm -o - -femit-all-decls | FileCheck --check-prefix SIMD-ONLY0 %s 8 // SIMD-ONLY0-NOT: {{__kmpc|__tgt}} 9 // expected-no-diagnostics 10 #ifndef HEADER 11 #define HEADER 12 13 void add_1(float *d); 14 15 #pragma omp declare simd linear(d : 8) 16 #pragma omp declare simd inbranch simdlen(32) 17 #pragma omp declare simd notinbranch 18 void add_1(float *d); 19 20 #pragma omp declare simd linear(d : 8) 21 #pragma omp declare simd inbranch simdlen(32) 22 #pragma omp declare simd notinbranch 23 void add_1(float *d) {} 24 25 void add_1(float *d); 26 27 #pragma omp declare simd linear(d : 8) 28 #pragma omp declare simd inbranch simdlen(32) 29 #pragma omp declare simd notinbranch 30 void add_2(float *d); 31 32 #pragma omp declare simd aligned(hp, hp2) 33 template <class C> 34 void h(C *hp, C *hp2, C *hq, C *lin) { 35 add_2(0); 36 } 37 38 // Explicit specialization with <C=int>. 39 // Pragmas need to be same, otherwise standard says that's undefined behavior. 40 #pragma omp declare simd aligned(hp, hp2) 41 template <> 42 void h(int *hp, int *hp2, int *hq, int *lin) { 43 // Implicit specialization with <C=float>. 44 // This is special case where the directive is stored by Sema and is 45 // generated together with the (pending) function instatiation. 46 h((float *)hp, (float *)hp2, (float *)hq, (float *)lin); 47 } 48 49 class VV { 50 public: 51 #pragma omp declare simd uniform(this, a) linear(val(b) : a) 52 int add(int a, int b) __attribute__((cold)) { return a + b; } 53 54 #pragma omp declare simd aligned(b : 4) aligned(a) linear(ref(b) : 4) linear(this, a) 55 float taddpf(float *a, float *&b) { return *a + *b; } 56 57 #pragma omp declare simd linear(uval(c) : 8) 58 #pragma omp declare simd aligned(b : 8) 59 int tadd(int (&b)[], int &c) { return x[b[0]] + b[0]; } 60 61 private: 62 int x[10]; 63 } vv; 64 65 template <int X, typename T> 66 class TVV { 67 public: 68 #pragma omp declare simd simdlen(X) 69 int tadd(int a, int b) { return a + b; } 70 71 #pragma omp declare simd aligned(a : X * 2) aligned(b) linear(ref(b) : X) 72 float taddpf(float *a, T *&b) { return *a + *b; } 73 74 #pragma omp declare simd 75 #pragma omp declare simd uniform(this, b) 76 int tadd(int b) { return x[b] + b; } 77 78 private: 79 int x[X]; 80 }; 81 82 #pragma omp declare simd simdlen(N) aligned(b : N * 2) linear(uval(c) : N) 83 template <int N> 84 void foo(int (&b)[N], float *&c) {} 85 86 TVV<16, float> t16; 87 88 void f(int (&g)[]) { 89 float a = 1.0f, b = 2.0f; 90 float *p = &b; 91 float r = t16.taddpf(&a, p); 92 int res = t16.tadd(b); 93 int c[64]; 94 vv.add(res, res); 95 vv.taddpf(p, p); 96 vv.tadd(g, res); 97 foo(c, p); 98 } 99 100 #pragma omp declare simd 101 #pragma omp declare simd notinbranch aligned(a : 32) 102 int bar(VV v, float *a) { return 0; } 103 #pragma omp declare simd 104 #pragma omp declare simd notinbranch aligned(a) 105 float baz(VV v, int a[]) { return 0; } 106 #pragma omp declare simd 107 #pragma omp declare simd notinbranch aligned(a) 108 double bay(VV v, double *&a) { return 0; } 109 #pragma omp declare simd 110 #pragma omp declare simd inbranch linear(a : b) uniform(v, b) 111 void bax(VV v, double *a, int b) {} 112 #pragma omp declare simd uniform(q) aligned(q : 16) linear(k : 1) 113 float foo(float *q, float x, int k) { return 0; } 114 #pragma omp declare simd notinbranch 115 double foo(double x) { return 0; } 116 117 #pragma omp declare simd notinbranch linear(i) 118 double constlinear(const int i) { return 0.0; } 119 120 // Test linear modifiers 121 // linear(x) cases 122 #pragma omp declare simd simdlen(4) linear(a:2) linear(b:4) linear(c:8) \ 123 linear(d,e,f) 124 double One(int &a, int *b, int c, int &d, int *e, int f) { 125 return a + *b + c; 126 } 127 128 // linear(val(x)) cases 129 #pragma omp declare simd simdlen(4) linear(val(a):2) linear(val(b):4) \ 130 linear(val(c):8) linear(val(d,e,f)) 131 double Two(int &a, int *b, int c, int &d, int *e, int f) { 132 return a + *b + c; 133 } 134 135 // linear(uval(x) case 136 #pragma omp declare simd simdlen(4) linear(uval(a):2) linear(uval(b)) 137 double Three(int &a, int &b) { 138 return a; 139 } 140 141 // linear(ref(x) case 142 #pragma omp declare simd simdlen(4) linear(ref(a):2) linear(ref(b)) 143 double Four(int& a, int &b) { 144 return a; 145 } 146 147 // Test reference parameters with variable stride. 148 #pragma omp declare simd simdlen(4) uniform(a) \ 149 linear(b:2) linear(c:a) \ 150 linear(val(d):4) linear(val(e):a) \ 151 linear(uval(f):8) linear(uval(g):a) \ 152 linear(ref(h):16) linear(ref(i):a) 153 double Five(int a, short &b, short &c, short &d, short &e, short &f, short &g, 154 short &h, short &i) { 155 return a + int(b); 156 } 157 158 // Test negative strides 159 #pragma omp declare simd simdlen(4) linear(a:-2) linear(b:-8) \ 160 linear(uval(c):-4) linear(ref(d):-16) \ 161 linear(e:-1) linear(f:-1) linear(g:0) 162 double Six(int a, float *b, int &c, int *&d, char e, char *f, short g) { 163 return a + int(*b) + c + *d + e + *f + g; 164 } 165 166 // CHECK-DAG: define {{.+}}@_Z5add_1Pf( 167 // CHECK-DAG: define {{.+}}@_Z1hIiEvPT_S1_S1_S1_( 168 // CHECK-DAG: define {{.+}}@_Z1hIfEvPT_S1_S1_S1_( 169 // CHECK-DAG: define {{.+}}@_ZN2VV3addEii( 170 // CHECK-DAG: define {{.+}}@_ZN2VV6taddpfEPfRS0_( 171 // CHECK-DAG: define {{.+}}@_ZN2VV4taddERA_iRi( 172 // CHECK-DAG: define {{.+}}@_Z1fRA_i( 173 // CHECK-DAG: define {{.+}}@_ZN3TVVILi16EfE6taddpfEPfRS1_( 174 // CHECK-DAG: define {{.+}}@_ZN3TVVILi16EfE4taddEi( 175 // CHECK-DAG: define {{.+}}@_Z3fooILi64EEvRAT__iRPf( 176 // CHECK-DAG: define {{.+}}@_Z3bar2VVPf( 177 // CHECK-DAG: define {{.+}}@_Z3baz2VVPi( 178 // CHECK-DAG: define {{.+}}@_Z3bay2VVRPd( 179 // CHECK-DAG: define {{.+}}@_Z3bax2VVPdi( 180 // CHECK-DAG: define {{.+}}@_Z3fooPffi( 181 // CHECK-DAG: define {{.+}}@_Z3food( 182 // CHECK-DAG: declare {{.+}}@_Z5add_2Pf( 183 // CHECK-DAG: define {{.+}}@_Z11constlineari( 184 // CHECK-DAG: define {{.+}}@_Z3OneRiPiiS_S0_i 185 // CHECK-DAG: define {{.+}}@_Z3TwoRiPiiS_S0_i 186 // CHECK-DAG: define {{.+}}@_Z5ThreeRiS_ 187 // CHECK-DAG: define {{.+}}@_Z4FourRiS_ 188 // CHECK-DAG: define {{.+}}@_Z4FiveiRsS_S_S_S_S_S_S_ 189 // CHECK-DAG: define {{.+}}@_Z3SixiPfRiRPicPcs 190 191 // CHECK-DAG: "_ZGVbM4l32__Z5add_1Pf" 192 // CHECK-DAG: "_ZGVbN4l32__Z5add_1Pf" 193 // CHECK-DAG: "_ZGVcM8l32__Z5add_1Pf" 194 // CHECK-DAG: "_ZGVcN8l32__Z5add_1Pf" 195 // CHECK-DAG: "_ZGVdM8l32__Z5add_1Pf" 196 // CHECK-DAG: "_ZGVdN8l32__Z5add_1Pf" 197 // CHECK-DAG: "_ZGVeM16l32__Z5add_1Pf" 198 // CHECK-DAG: "_ZGVeN16l32__Z5add_1Pf" 199 // CHECK-DAG: "_ZGVbM32v__Z5add_1Pf" 200 // CHECK-DAG: "_ZGVcM32v__Z5add_1Pf" 201 // CHECK-DAG: "_ZGVdM32v__Z5add_1Pf" 202 // CHECK-DAG: "_ZGVeM32v__Z5add_1Pf" 203 // CHECK-DAG: "_ZGVbN2v__Z5add_1Pf" 204 // CHECK-DAG: "_ZGVcN4v__Z5add_1Pf" 205 // CHECK-DAG: "_ZGVdN4v__Z5add_1Pf" 206 // CHECK-DAG: "_ZGVeN8v__Z5add_1Pf" 207 208 // CHECK-NOT: _ZGVbN2vv__Z5add_1Pf 209 // CHECK-NOT: _ZGVcN4vv__Z5add_1Pf 210 // CHECK-NOT: _ZGVdN4vv__Z5add_1Pf 211 // CHECK-NOT: _ZGVeN8vv__Z5add_1Pf 212 // CHECK-NOT: _ZGVbM32vv__Z5add_1Pf 213 // CHECK-NOT: _ZGVcM32vv__Z5add_1Pf 214 // CHECK-NOT: _ZGVdM32vv__Z5add_1Pf 215 // CHECK-NOT: _ZGVeM32vv__Z5add_1Pf 216 // CHECK-NOT: _ZGVbN4l32v__Z5add_1Pf 217 // CHECK-NOT: _ZGVcN8l32v__Z5add_1Pf 218 // CHECK-NOT: _ZGVdN8l32v__Z5add_1Pf 219 // CHECK-NOT: _ZGVeN16l32v__Z5add_1Pf 220 // CHECK-NOT: _ZGVbM4l32v__Z5add_1Pf 221 // CHECK-NOT: _ZGVcM8l32v__Z5add_1Pf 222 // CHECK-NOT: _ZGVdM8l32v__Z5add_1Pf 223 // CHECK-NOT: _ZGVeM16l32v__Z5add_1Pf 224 225 // CHECK-DAG: "_ZGVbM2va16va16vv__Z1hIiEvPT_S1_S1_S1_" 226 // CHECK-DAG: "_ZGVbN2va16va16vv__Z1hIiEvPT_S1_S1_S1_" 227 // CHECK-DAG: "_ZGVcM4va16va16vv__Z1hIiEvPT_S1_S1_S1_" 228 // CHECK-DAG: "_ZGVcN4va16va16vv__Z1hIiEvPT_S1_S1_S1_" 229 // CHECK-DAG: "_ZGVdM4va16va16vv__Z1hIiEvPT_S1_S1_S1_" 230 // CHECK-DAG: "_ZGVdN4va16va16vv__Z1hIiEvPT_S1_S1_S1_" 231 // CHECK-DAG: "_ZGVeM8va16va16vv__Z1hIiEvPT_S1_S1_S1_" 232 // CHECK-DAG: "_ZGVeN8va16va16vv__Z1hIiEvPT_S1_S1_S1_" 233 234 // CHECK-DAG: "_ZGVbM2va16va16vv__Z1hIfEvPT_S1_S1_S1_" 235 // CHECK-DAG: "_ZGVbN2va16va16vv__Z1hIfEvPT_S1_S1_S1_" 236 // CHECK-DAG: "_ZGVcM4va16va16vv__Z1hIfEvPT_S1_S1_S1_" 237 // CHECK-DAG: "_ZGVcN4va16va16vv__Z1hIfEvPT_S1_S1_S1_" 238 // CHECK-DAG: "_ZGVdM4va16va16vv__Z1hIfEvPT_S1_S1_S1_" 239 // CHECK-DAG: "_ZGVdN4va16va16vv__Z1hIfEvPT_S1_S1_S1_" 240 // CHECK-DAG: "_ZGVeM8va16va16vv__Z1hIfEvPT_S1_S1_S1_" 241 // CHECK-DAG: "_ZGVeN8va16va16vv__Z1hIfEvPT_S1_S1_S1_" 242 243 // CHECK-DAG: "_ZGVbM4uuls1__ZN2VV3addEii" 244 // CHECK-DAG: "_ZGVbN4uuls1__ZN2VV3addEii" 245 // CHECK-DAG: "_ZGVcM8uuls1__ZN2VV3addEii" 246 // CHECK-DAG: "_ZGVcN8uuls1__ZN2VV3addEii" 247 // CHECK-DAG: "_ZGVdM8uuls1__ZN2VV3addEii" 248 // CHECK-DAG: "_ZGVdN8uuls1__ZN2VV3addEii" 249 // CHECK-DAG: "_ZGVeM16uuls1__ZN2VV3addEii" 250 // CHECK-DAG: "_ZGVeN16uuls1__ZN2VV3addEii" 251 252 // CHECK-DAG: "_ZGVbM4l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 253 // CHECK-DAG: "_ZGVbN4l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 254 // CHECK-DAG: "_ZGVcM8l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 255 // CHECK-DAG: "_ZGVcN8l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 256 // CHECK-DAG: "_ZGVdM8l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 257 // CHECK-DAG: "_ZGVdN8l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 258 // CHECK-DAG: "_ZGVeM16l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 259 // CHECK-DAG: "_ZGVeN16l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 260 261 // CHECK-DAG: "_ZGVbM4vvU8__ZN2VV4taddERA_iRi" 262 // CHECK-DAG: "_ZGVbN4vvU8__ZN2VV4taddERA_iRi" 263 // CHECK-DAG: "_ZGVcM8vvU8__ZN2VV4taddERA_iRi" 264 // CHECK-DAG: "_ZGVcN8vvU8__ZN2VV4taddERA_iRi" 265 // CHECK-DAG: "_ZGVdM8vvU8__ZN2VV4taddERA_iRi" 266 // CHECK-DAG: "_ZGVdN8vvU8__ZN2VV4taddERA_iRi" 267 // CHECK-DAG: "_ZGVeM16vvU8__ZN2VV4taddERA_iRi" 268 // CHECK-DAG: "_ZGVeN16vvU8__ZN2VV4taddERA_iRi" 269 // CHECK-DAG: "_ZGVbM4vva8v__ZN2VV4taddERA_iRi" 270 // CHECK-DAG: "_ZGVbN4vva8v__ZN2VV4taddERA_iRi" 271 // CHECK-DAG: "_ZGVcM8vva8v__ZN2VV4taddERA_iRi" 272 // CHECK-DAG: "_ZGVcN8vva8v__ZN2VV4taddERA_iRi" 273 // CHECK-DAG: "_ZGVdM8vva8v__ZN2VV4taddERA_iRi" 274 // CHECK-DAG: "_ZGVdN8vva8v__ZN2VV4taddERA_iRi" 275 // CHECK-DAG: "_ZGVeM16vva8v__ZN2VV4taddERA_iRi" 276 // CHECK-DAG: "_ZGVeN16vva8v__ZN2VV4taddERA_iRi" 277 278 // CHECK-DAG: "_ZGVbM4vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 279 // CHECK-DAG: "_ZGVbN4vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 280 // CHECK-DAG: "_ZGVcM8vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 281 // CHECK-DAG: "_ZGVcN8vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 282 // CHECK-DAG: "_ZGVdM8vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 283 // CHECK-DAG: "_ZGVdN8vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 284 // CHECK-DAG: "_ZGVeM16vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 285 // CHECK-DAG: "_ZGVeN16vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 286 287 // CHECK-DAG: "_ZGVbM4uu__ZN3TVVILi16EfE4taddEi" 288 // CHECK-DAG: "_ZGVbN4uu__ZN3TVVILi16EfE4taddEi" 289 // CHECK-DAG: "_ZGVcM8uu__ZN3TVVILi16EfE4taddEi" 290 // CHECK-DAG: "_ZGVcN8uu__ZN3TVVILi16EfE4taddEi" 291 // CHECK-DAG: "_ZGVdM8uu__ZN3TVVILi16EfE4taddEi" 292 // CHECK-DAG: "_ZGVdN8uu__ZN3TVVILi16EfE4taddEi" 293 // CHECK-DAG: "_ZGVeM16uu__ZN3TVVILi16EfE4taddEi" 294 // CHECK-DAG: "_ZGVeN16uu__ZN3TVVILi16EfE4taddEi" 295 // CHECK-DAG: "_ZGVbM4vv__ZN3TVVILi16EfE4taddEi" 296 // CHECK-DAG: "_ZGVbN4vv__ZN3TVVILi16EfE4taddEi" 297 // CHECK-DAG: "_ZGVcM8vv__ZN3TVVILi16EfE4taddEi" 298 // CHECK-DAG: "_ZGVcN8vv__ZN3TVVILi16EfE4taddEi" 299 // CHECK-DAG: "_ZGVdM8vv__ZN3TVVILi16EfE4taddEi" 300 // CHECK-DAG: "_ZGVdN8vv__ZN3TVVILi16EfE4taddEi" 301 // CHECK-DAG: "_ZGVeM16vv__ZN3TVVILi16EfE4taddEi" 302 // CHECK-DAG: "_ZGVeN16vv__ZN3TVVILi16EfE4taddEi" 303 304 // CHECK-DAG: "_ZGVbM64va128U64__Z3fooILi64EEvRAT__iRPf" 305 // CHECK-DAG: "_ZGVbN64va128U64__Z3fooILi64EEvRAT__iRPf" 306 // CHECK-DAG: "_ZGVcM64va128U64__Z3fooILi64EEvRAT__iRPf" 307 // CHECK-DAG: "_ZGVcN64va128U64__Z3fooILi64EEvRAT__iRPf" 308 // CHECK-DAG: "_ZGVdM64va128U64__Z3fooILi64EEvRAT__iRPf" 309 // CHECK-DAG: "_ZGVdN64va128U64__Z3fooILi64EEvRAT__iRPf" 310 // CHECK-DAG: "_ZGVeM64va128U64__Z3fooILi64EEvRAT__iRPf" 311 // CHECK-DAG: "_ZGVeN64va128U64__Z3fooILi64EEvRAT__iRPf" 312 313 // CHECK-DAG: "_ZGVbM4vv__Z3bar2VVPf" 314 // CHECK-DAG: "_ZGVbN4vv__Z3bar2VVPf" 315 // CHECK-DAG: "_ZGVcM8vv__Z3bar2VVPf" 316 // CHECK-DAG: "_ZGVcN8vv__Z3bar2VVPf" 317 // CHECK-DAG: "_ZGVdM8vv__Z3bar2VVPf" 318 // CHECK-DAG: "_ZGVdN8vv__Z3bar2VVPf" 319 // CHECK-DAG: "_ZGVeM16vv__Z3bar2VVPf" 320 // CHECK-DAG: "_ZGVeN16vv__Z3bar2VVPf" 321 // CHECK-DAG: "_ZGVbN4vva32__Z3bar2VVPf" 322 // CHECK-DAG: "_ZGVcN8vva32__Z3bar2VVPf" 323 // CHECK-DAG: "_ZGVdN8vva32__Z3bar2VVPf" 324 // CHECK-DAG: "_ZGVeN16vva32__Z3bar2VVPf" 325 326 // CHECK-DAG: "_ZGVbM4vv__Z3baz2VVPi" 327 // CHECK-DAG: "_ZGVbN4vv__Z3baz2VVPi" 328 // CHECK-DAG: "_ZGVcM8vv__Z3baz2VVPi" 329 // CHECK-DAG: "_ZGVcN8vv__Z3baz2VVPi" 330 // CHECK-DAG: "_ZGVdM8vv__Z3baz2VVPi" 331 // CHECK-DAG: "_ZGVdN8vv__Z3baz2VVPi" 332 // CHECK-DAG: "_ZGVeM16vv__Z3baz2VVPi" 333 // CHECK-DAG: "_ZGVeN16vv__Z3baz2VVPi" 334 // CHECK-DAG: "_ZGVbN4vva16__Z3baz2VVPi" 335 // CHECK-DAG: "_ZGVcN8vva16__Z3baz2VVPi" 336 // CHECK-DAG: "_ZGVdN8vva16__Z3baz2VVPi" 337 // CHECK-DAG: "_ZGVeN16vva16__Z3baz2VVPi" 338 339 // CHECK-DAG: "_ZGVbM2vv__Z3bay2VVRPd" 340 // CHECK-DAG: "_ZGVbN2vv__Z3bay2VVRPd" 341 // CHECK-DAG: "_ZGVcM4vv__Z3bay2VVRPd" 342 // CHECK-DAG: "_ZGVcN4vv__Z3bay2VVRPd" 343 // CHECK-DAG: "_ZGVdM4vv__Z3bay2VVRPd" 344 // CHECK-DAG: "_ZGVdN4vv__Z3bay2VVRPd" 345 // CHECK-DAG: "_ZGVeM8vv__Z3bay2VVRPd" 346 // CHECK-DAG: "_ZGVeN8vv__Z3bay2VVRPd" 347 // CHECK-DAG: "_ZGVbN2vva16__Z3bay2VVRPd" 348 // CHECK-DAG: "_ZGVcN4vva16__Z3bay2VVRPd" 349 // CHECK-DAG: "_ZGVdN4vva16__Z3bay2VVRPd" 350 // CHECK-DAG: "_ZGVeN8vva16__Z3bay2VVRPd" 351 352 // CHECK-DAG: "_ZGVbM4uls2u__Z3bax2VVPdi" 353 // CHECK-DAG: "_ZGVcM8uls2u__Z3bax2VVPdi" 354 // CHECK-DAG: "_ZGVdM8uls2u__Z3bax2VVPdi" 355 // CHECK-DAG: "_ZGVeM16uls2u__Z3bax2VVPdi" 356 // CHECK-DAG: "_ZGVbM4vvv__Z3bax2VVPdi" 357 // CHECK-DAG: "_ZGVbN4vvv__Z3bax2VVPdi" 358 // CHECK-DAG: "_ZGVcM8vvv__Z3bax2VVPdi" 359 // CHECK-DAG: "_ZGVcN8vvv__Z3bax2VVPdi" 360 // CHECK-DAG: "_ZGVdM8vvv__Z3bax2VVPdi" 361 // CHECK-DAG: "_ZGVdN8vvv__Z3bax2VVPdi" 362 // CHECK-DAG: "_ZGVeM16vvv__Z3bax2VVPdi" 363 // CHECK-DAG: "_ZGVeN16vvv__Z3bax2VVPdi" 364 365 // CHECK-DAG: "_ZGVbM4ua16vl__Z3fooPffi" 366 // CHECK-DAG: "_ZGVbN4ua16vl__Z3fooPffi" 367 // CHECK-DAG: "_ZGVcM8ua16vl__Z3fooPffi" 368 // CHECK-DAG: "_ZGVcN8ua16vl__Z3fooPffi" 369 // CHECK-DAG: "_ZGVdM8ua16vl__Z3fooPffi" 370 // CHECK-DAG: "_ZGVdN8ua16vl__Z3fooPffi" 371 // CHECK-DAG: "_ZGVeM16ua16vl__Z3fooPffi" 372 // CHECK-DAG: "_ZGVeN16ua16vl__Z3fooPffi" 373 374 // CHECK-DAG: "_ZGVbM4l32__Z5add_2Pf" 375 // CHECK-DAG: "_ZGVbN4l32__Z5add_2Pf" 376 // CHECK-DAG: "_ZGVcM8l32__Z5add_2Pf" 377 // CHECK-DAG: "_ZGVcN8l32__Z5add_2Pf" 378 // CHECK-DAG: "_ZGVdM8l32__Z5add_2Pf" 379 // CHECK-DAG: "_ZGVdN8l32__Z5add_2Pf" 380 // CHECK-DAG: "_ZGVeM16l32__Z5add_2Pf" 381 // CHECK-DAG: "_ZGVeN16l32__Z5add_2Pf" 382 // CHECK-DAG: "_ZGVbM32v__Z5add_2Pf" 383 // CHECK-DAG: "_ZGVcM32v__Z5add_2Pf" 384 // CHECK-DAG: "_ZGVdM32v__Z5add_2Pf" 385 // CHECK-DAG: "_ZGVeM32v__Z5add_2Pf" 386 // CHECK-DAG: "_ZGVbN2v__Z5add_2Pf" 387 // CHECK-DAG: "_ZGVcN4v__Z5add_2Pf" 388 // CHECK-DAG: "_ZGVdN4v__Z5add_2Pf" 389 // CHECK-DAG: "_ZGVeN8v__Z5add_2Pf" 390 391 // CHECK-DAG: "_ZGVbN2v__Z3food" 392 // CHECK-DAG: "_ZGVcN4v__Z3food" 393 // CHECK-DAG: "_ZGVdN4v__Z3food" 394 // CHECK-DAG: "_ZGVeN8v__Z3food" 395 396 // CHECK-DAG: "_ZGVbN2l__Z11constlineari" 397 // CHECK-DAG: "_ZGVcN4l__Z11constlineari" 398 // CHECK-DAG: "_ZGVdN4l__Z11constlineari" 399 // CHECK-DAG: "_ZGVeN8l__Z11constlineari" 400 401 // CHECK-DAG: "_ZGVbM4L2l16l8Ll4l__Z3OneRiPiiS_S0_i" 402 // CHECK-DAG: "_ZGVbN4L2l16l8Ll4l__Z3OneRiPiiS_S0_i" 403 // CHECK-DAG: "_ZGVbM4L2l16l8Ll4l__Z3TwoRiPiiS_S0_i" 404 // CHECK-DAG: "_ZGVbN4L2l16l8Ll4l__Z3TwoRiPiiS_S0_i" 405 // CHECK-DAG: "_ZGVbM4U2U__Z5ThreeRiS_" 406 // CHECK-DAG: "_ZGVbN4U2U__Z5ThreeRiS_" 407 // CHECK-DAG: "_ZGVbM4R8R4__Z4FourRiS_" 408 // CHECK-DAG: "_ZGVbN4R8R4__Z4FourRiS_" 409 // CHECK-DAG: "_ZGVbM4uL2Ls0L4Ls0U8Us0R32Rs0__Z4FiveiRsS_S_S_S_S_S_S_" 410 // CHECK-DAG: "_ZGVbN4uL2Ls0L4Ls0U8Us0R32Rs0__Z4FiveiRsS_S_S_S_S_S_S_" 411 // CHECK-DAG: "_ZGVbM4ln2ln32Un4Rn128ln1ln1l0__Z3SixiPfRiRPicPcs" 412 // CHECK-DAG: "_ZGVbN4ln2ln32Un4Rn128ln1ln1l0__Z3SixiPfRiRPicPcs" 413 414 // CHECK-NOT: "_ZGV{{.+}}__Z1fRA_i 415 416 #endif 417