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 // CHECK-DAG: define {{.+}}@_Z5add_1Pf( 159 // CHECK-DAG: define {{.+}}@_Z1hIiEvPT_S1_S1_S1_( 160 // CHECK-DAG: define {{.+}}@_Z1hIfEvPT_S1_S1_S1_( 161 // CHECK-DAG: define {{.+}}@_ZN2VV3addEii( 162 // CHECK-DAG: define {{.+}}@_ZN2VV6taddpfEPfRS0_( 163 // CHECK-DAG: define {{.+}}@_ZN2VV4taddERA_iRi( 164 // CHECK-DAG: define {{.+}}@_Z1fRA_i( 165 // CHECK-DAG: define {{.+}}@_ZN3TVVILi16EfE6taddpfEPfRS1_( 166 // CHECK-DAG: define {{.+}}@_ZN3TVVILi16EfE4taddEi( 167 // CHECK-DAG: define {{.+}}@_Z3fooILi64EEvRAT__iRPf( 168 // CHECK-DAG: define {{.+}}@_Z3bar2VVPf( 169 // CHECK-DAG: define {{.+}}@_Z3baz2VVPi( 170 // CHECK-DAG: define {{.+}}@_Z3bay2VVRPd( 171 // CHECK-DAG: define {{.+}}@_Z3bax2VVPdi( 172 // CHECK-DAG: define {{.+}}@_Z3fooPffi( 173 // CHECK-DAG: define {{.+}}@_Z3food( 174 // CHECK-DAG: declare {{.+}}@_Z5add_2Pf( 175 // CHECK-DAG: define {{.+}}@_Z11constlineari( 176 // CHECK-DAG: define {{.+}}@_Z3OneRiPiiS_S0_i 177 // CHECK-DAG: define {{.+}}@_Z3TwoRiPiiS_S0_i 178 // CHECK-DAG: define {{.+}}@_Z5ThreeRiS_ 179 // CHECK-DAG: define {{.+}}@_Z4FourRiS_ 180 // CHECK-DAG: define {{.+}}@_Z4FiveiRsS_S_S_S_S_S_S_ 181 182 // CHECK-DAG: "_ZGVbM4l32__Z5add_1Pf" 183 // CHECK-DAG: "_ZGVbN4l32__Z5add_1Pf" 184 // CHECK-DAG: "_ZGVcM8l32__Z5add_1Pf" 185 // CHECK-DAG: "_ZGVcN8l32__Z5add_1Pf" 186 // CHECK-DAG: "_ZGVdM8l32__Z5add_1Pf" 187 // CHECK-DAG: "_ZGVdN8l32__Z5add_1Pf" 188 // CHECK-DAG: "_ZGVeM16l32__Z5add_1Pf" 189 // CHECK-DAG: "_ZGVeN16l32__Z5add_1Pf" 190 // CHECK-DAG: "_ZGVbM32v__Z5add_1Pf" 191 // CHECK-DAG: "_ZGVcM32v__Z5add_1Pf" 192 // CHECK-DAG: "_ZGVdM32v__Z5add_1Pf" 193 // CHECK-DAG: "_ZGVeM32v__Z5add_1Pf" 194 // CHECK-DAG: "_ZGVbN2v__Z5add_1Pf" 195 // CHECK-DAG: "_ZGVcN4v__Z5add_1Pf" 196 // CHECK-DAG: "_ZGVdN4v__Z5add_1Pf" 197 // CHECK-DAG: "_ZGVeN8v__Z5add_1Pf" 198 199 // CHECK-NOT: _ZGVbN2vv__Z5add_1Pf 200 // CHECK-NOT: _ZGVcN4vv__Z5add_1Pf 201 // CHECK-NOT: _ZGVdN4vv__Z5add_1Pf 202 // CHECK-NOT: _ZGVeN8vv__Z5add_1Pf 203 // CHECK-NOT: _ZGVbM32vv__Z5add_1Pf 204 // CHECK-NOT: _ZGVcM32vv__Z5add_1Pf 205 // CHECK-NOT: _ZGVdM32vv__Z5add_1Pf 206 // CHECK-NOT: _ZGVeM32vv__Z5add_1Pf 207 // CHECK-NOT: _ZGVbN4l32v__Z5add_1Pf 208 // CHECK-NOT: _ZGVcN8l32v__Z5add_1Pf 209 // CHECK-NOT: _ZGVdN8l32v__Z5add_1Pf 210 // CHECK-NOT: _ZGVeN16l32v__Z5add_1Pf 211 // CHECK-NOT: _ZGVbM4l32v__Z5add_1Pf 212 // CHECK-NOT: _ZGVcM8l32v__Z5add_1Pf 213 // CHECK-NOT: _ZGVdM8l32v__Z5add_1Pf 214 // CHECK-NOT: _ZGVeM16l32v__Z5add_1Pf 215 216 // CHECK-DAG: "_ZGVbM2va16va16vv__Z1hIiEvPT_S1_S1_S1_" 217 // CHECK-DAG: "_ZGVbN2va16va16vv__Z1hIiEvPT_S1_S1_S1_" 218 // CHECK-DAG: "_ZGVcM4va16va16vv__Z1hIiEvPT_S1_S1_S1_" 219 // CHECK-DAG: "_ZGVcN4va16va16vv__Z1hIiEvPT_S1_S1_S1_" 220 // CHECK-DAG: "_ZGVdM4va16va16vv__Z1hIiEvPT_S1_S1_S1_" 221 // CHECK-DAG: "_ZGVdN4va16va16vv__Z1hIiEvPT_S1_S1_S1_" 222 // CHECK-DAG: "_ZGVeM8va16va16vv__Z1hIiEvPT_S1_S1_S1_" 223 // CHECK-DAG: "_ZGVeN8va16va16vv__Z1hIiEvPT_S1_S1_S1_" 224 225 // CHECK-DAG: "_ZGVbM2va16va16vv__Z1hIfEvPT_S1_S1_S1_" 226 // CHECK-DAG: "_ZGVbN2va16va16vv__Z1hIfEvPT_S1_S1_S1_" 227 // CHECK-DAG: "_ZGVcM4va16va16vv__Z1hIfEvPT_S1_S1_S1_" 228 // CHECK-DAG: "_ZGVcN4va16va16vv__Z1hIfEvPT_S1_S1_S1_" 229 // CHECK-DAG: "_ZGVdM4va16va16vv__Z1hIfEvPT_S1_S1_S1_" 230 // CHECK-DAG: "_ZGVdN4va16va16vv__Z1hIfEvPT_S1_S1_S1_" 231 // CHECK-DAG: "_ZGVeM8va16va16vv__Z1hIfEvPT_S1_S1_S1_" 232 // CHECK-DAG: "_ZGVeN8va16va16vv__Z1hIfEvPT_S1_S1_S1_" 233 234 // CHECK-DAG: "_ZGVbM4uuls1__ZN2VV3addEii" 235 // CHECK-DAG: "_ZGVbN4uuls1__ZN2VV3addEii" 236 // CHECK-DAG: "_ZGVcM8uuls1__ZN2VV3addEii" 237 // CHECK-DAG: "_ZGVcN8uuls1__ZN2VV3addEii" 238 // CHECK-DAG: "_ZGVdM8uuls1__ZN2VV3addEii" 239 // CHECK-DAG: "_ZGVdN8uuls1__ZN2VV3addEii" 240 // CHECK-DAG: "_ZGVeM16uuls1__ZN2VV3addEii" 241 // CHECK-DAG: "_ZGVeN16uuls1__ZN2VV3addEii" 242 243 // CHECK-DAG: "_ZGVbM4l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 244 // CHECK-DAG: "_ZGVbN4l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 245 // CHECK-DAG: "_ZGVcM8l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 246 // CHECK-DAG: "_ZGVcN8l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 247 // CHECK-DAG: "_ZGVdM8l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 248 // CHECK-DAG: "_ZGVdN8l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 249 // CHECK-DAG: "_ZGVeM16l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 250 // CHECK-DAG: "_ZGVeN16l40l4a16R32a4__ZN2VV6taddpfEPfRS0_" 251 252 // CHECK-DAG: "_ZGVbM4vvU8__ZN2VV4taddERA_iRi" 253 // CHECK-DAG: "_ZGVbN4vvU8__ZN2VV4taddERA_iRi" 254 // CHECK-DAG: "_ZGVcM8vvU8__ZN2VV4taddERA_iRi" 255 // CHECK-DAG: "_ZGVcN8vvU8__ZN2VV4taddERA_iRi" 256 // CHECK-DAG: "_ZGVdM8vvU8__ZN2VV4taddERA_iRi" 257 // CHECK-DAG: "_ZGVdN8vvU8__ZN2VV4taddERA_iRi" 258 // CHECK-DAG: "_ZGVeM16vvU8__ZN2VV4taddERA_iRi" 259 // CHECK-DAG: "_ZGVeN16vvU8__ZN2VV4taddERA_iRi" 260 // CHECK-DAG: "_ZGVbM4vva8v__ZN2VV4taddERA_iRi" 261 // CHECK-DAG: "_ZGVbN4vva8v__ZN2VV4taddERA_iRi" 262 // CHECK-DAG: "_ZGVcM8vva8v__ZN2VV4taddERA_iRi" 263 // CHECK-DAG: "_ZGVcN8vva8v__ZN2VV4taddERA_iRi" 264 // CHECK-DAG: "_ZGVdM8vva8v__ZN2VV4taddERA_iRi" 265 // CHECK-DAG: "_ZGVdN8vva8v__ZN2VV4taddERA_iRi" 266 // CHECK-DAG: "_ZGVeM16vva8v__ZN2VV4taddERA_iRi" 267 // CHECK-DAG: "_ZGVeN16vva8v__ZN2VV4taddERA_iRi" 268 269 // CHECK-DAG: "_ZGVbM4vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 270 // CHECK-DAG: "_ZGVbN4vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 271 // CHECK-DAG: "_ZGVcM8vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 272 // CHECK-DAG: "_ZGVcN8vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 273 // CHECK-DAG: "_ZGVdM8vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 274 // CHECK-DAG: "_ZGVdN8vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 275 // CHECK-DAG: "_ZGVeM16vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 276 // CHECK-DAG: "_ZGVeN16vva32R128a16__ZN3TVVILi16EfE6taddpfEPfRS1_" 277 278 // CHECK-DAG: "_ZGVbM4uu__ZN3TVVILi16EfE4taddEi" 279 // CHECK-DAG: "_ZGVbN4uu__ZN3TVVILi16EfE4taddEi" 280 // CHECK-DAG: "_ZGVcM8uu__ZN3TVVILi16EfE4taddEi" 281 // CHECK-DAG: "_ZGVcN8uu__ZN3TVVILi16EfE4taddEi" 282 // CHECK-DAG: "_ZGVdM8uu__ZN3TVVILi16EfE4taddEi" 283 // CHECK-DAG: "_ZGVdN8uu__ZN3TVVILi16EfE4taddEi" 284 // CHECK-DAG: "_ZGVeM16uu__ZN3TVVILi16EfE4taddEi" 285 // CHECK-DAG: "_ZGVeN16uu__ZN3TVVILi16EfE4taddEi" 286 // CHECK-DAG: "_ZGVbM4vv__ZN3TVVILi16EfE4taddEi" 287 // CHECK-DAG: "_ZGVbN4vv__ZN3TVVILi16EfE4taddEi" 288 // CHECK-DAG: "_ZGVcM8vv__ZN3TVVILi16EfE4taddEi" 289 // CHECK-DAG: "_ZGVcN8vv__ZN3TVVILi16EfE4taddEi" 290 // CHECK-DAG: "_ZGVdM8vv__ZN3TVVILi16EfE4taddEi" 291 // CHECK-DAG: "_ZGVdN8vv__ZN3TVVILi16EfE4taddEi" 292 // CHECK-DAG: "_ZGVeM16vv__ZN3TVVILi16EfE4taddEi" 293 // CHECK-DAG: "_ZGVeN16vv__ZN3TVVILi16EfE4taddEi" 294 295 // CHECK-DAG: "_ZGVbM64va128U64__Z3fooILi64EEvRAT__iRPf" 296 // CHECK-DAG: "_ZGVbN64va128U64__Z3fooILi64EEvRAT__iRPf" 297 // CHECK-DAG: "_ZGVcM64va128U64__Z3fooILi64EEvRAT__iRPf" 298 // CHECK-DAG: "_ZGVcN64va128U64__Z3fooILi64EEvRAT__iRPf" 299 // CHECK-DAG: "_ZGVdM64va128U64__Z3fooILi64EEvRAT__iRPf" 300 // CHECK-DAG: "_ZGVdN64va128U64__Z3fooILi64EEvRAT__iRPf" 301 // CHECK-DAG: "_ZGVeM64va128U64__Z3fooILi64EEvRAT__iRPf" 302 // CHECK-DAG: "_ZGVeN64va128U64__Z3fooILi64EEvRAT__iRPf" 303 304 // CHECK-DAG: "_ZGVbM4vv__Z3bar2VVPf" 305 // CHECK-DAG: "_ZGVbN4vv__Z3bar2VVPf" 306 // CHECK-DAG: "_ZGVcM8vv__Z3bar2VVPf" 307 // CHECK-DAG: "_ZGVcN8vv__Z3bar2VVPf" 308 // CHECK-DAG: "_ZGVdM8vv__Z3bar2VVPf" 309 // CHECK-DAG: "_ZGVdN8vv__Z3bar2VVPf" 310 // CHECK-DAG: "_ZGVeM16vv__Z3bar2VVPf" 311 // CHECK-DAG: "_ZGVeN16vv__Z3bar2VVPf" 312 // CHECK-DAG: "_ZGVbN4vva32__Z3bar2VVPf" 313 // CHECK-DAG: "_ZGVcN8vva32__Z3bar2VVPf" 314 // CHECK-DAG: "_ZGVdN8vva32__Z3bar2VVPf" 315 // CHECK-DAG: "_ZGVeN16vva32__Z3bar2VVPf" 316 317 // CHECK-DAG: "_ZGVbM4vv__Z3baz2VVPi" 318 // CHECK-DAG: "_ZGVbN4vv__Z3baz2VVPi" 319 // CHECK-DAG: "_ZGVcM8vv__Z3baz2VVPi" 320 // CHECK-DAG: "_ZGVcN8vv__Z3baz2VVPi" 321 // CHECK-DAG: "_ZGVdM8vv__Z3baz2VVPi" 322 // CHECK-DAG: "_ZGVdN8vv__Z3baz2VVPi" 323 // CHECK-DAG: "_ZGVeM16vv__Z3baz2VVPi" 324 // CHECK-DAG: "_ZGVeN16vv__Z3baz2VVPi" 325 // CHECK-DAG: "_ZGVbN4vva16__Z3baz2VVPi" 326 // CHECK-DAG: "_ZGVcN8vva16__Z3baz2VVPi" 327 // CHECK-DAG: "_ZGVdN8vva16__Z3baz2VVPi" 328 // CHECK-DAG: "_ZGVeN16vva16__Z3baz2VVPi" 329 330 // CHECK-DAG: "_ZGVbM2vv__Z3bay2VVRPd" 331 // CHECK-DAG: "_ZGVbN2vv__Z3bay2VVRPd" 332 // CHECK-DAG: "_ZGVcM4vv__Z3bay2VVRPd" 333 // CHECK-DAG: "_ZGVcN4vv__Z3bay2VVRPd" 334 // CHECK-DAG: "_ZGVdM4vv__Z3bay2VVRPd" 335 // CHECK-DAG: "_ZGVdN4vv__Z3bay2VVRPd" 336 // CHECK-DAG: "_ZGVeM8vv__Z3bay2VVRPd" 337 // CHECK-DAG: "_ZGVeN8vv__Z3bay2VVRPd" 338 // CHECK-DAG: "_ZGVbN2vva16__Z3bay2VVRPd" 339 // CHECK-DAG: "_ZGVcN4vva16__Z3bay2VVRPd" 340 // CHECK-DAG: "_ZGVdN4vva16__Z3bay2VVRPd" 341 // CHECK-DAG: "_ZGVeN8vva16__Z3bay2VVRPd" 342 343 // CHECK-DAG: "_ZGVbM4uls2u__Z3bax2VVPdi" 344 // CHECK-DAG: "_ZGVcM8uls2u__Z3bax2VVPdi" 345 // CHECK-DAG: "_ZGVdM8uls2u__Z3bax2VVPdi" 346 // CHECK-DAG: "_ZGVeM16uls2u__Z3bax2VVPdi" 347 // CHECK-DAG: "_ZGVbM4vvv__Z3bax2VVPdi" 348 // CHECK-DAG: "_ZGVbN4vvv__Z3bax2VVPdi" 349 // CHECK-DAG: "_ZGVcM8vvv__Z3bax2VVPdi" 350 // CHECK-DAG: "_ZGVcN8vvv__Z3bax2VVPdi" 351 // CHECK-DAG: "_ZGVdM8vvv__Z3bax2VVPdi" 352 // CHECK-DAG: "_ZGVdN8vvv__Z3bax2VVPdi" 353 // CHECK-DAG: "_ZGVeM16vvv__Z3bax2VVPdi" 354 // CHECK-DAG: "_ZGVeN16vvv__Z3bax2VVPdi" 355 356 // CHECK-DAG: "_ZGVbM4ua16vl__Z3fooPffi" 357 // CHECK-DAG: "_ZGVbN4ua16vl__Z3fooPffi" 358 // CHECK-DAG: "_ZGVcM8ua16vl__Z3fooPffi" 359 // CHECK-DAG: "_ZGVcN8ua16vl__Z3fooPffi" 360 // CHECK-DAG: "_ZGVdM8ua16vl__Z3fooPffi" 361 // CHECK-DAG: "_ZGVdN8ua16vl__Z3fooPffi" 362 // CHECK-DAG: "_ZGVeM16ua16vl__Z3fooPffi" 363 // CHECK-DAG: "_ZGVeN16ua16vl__Z3fooPffi" 364 365 // CHECK-DAG: "_ZGVbM4l32__Z5add_2Pf" 366 // CHECK-DAG: "_ZGVbN4l32__Z5add_2Pf" 367 // CHECK-DAG: "_ZGVcM8l32__Z5add_2Pf" 368 // CHECK-DAG: "_ZGVcN8l32__Z5add_2Pf" 369 // CHECK-DAG: "_ZGVdM8l32__Z5add_2Pf" 370 // CHECK-DAG: "_ZGVdN8l32__Z5add_2Pf" 371 // CHECK-DAG: "_ZGVeM16l32__Z5add_2Pf" 372 // CHECK-DAG: "_ZGVeN16l32__Z5add_2Pf" 373 // CHECK-DAG: "_ZGVbM32v__Z5add_2Pf" 374 // CHECK-DAG: "_ZGVcM32v__Z5add_2Pf" 375 // CHECK-DAG: "_ZGVdM32v__Z5add_2Pf" 376 // CHECK-DAG: "_ZGVeM32v__Z5add_2Pf" 377 // CHECK-DAG: "_ZGVbN2v__Z5add_2Pf" 378 // CHECK-DAG: "_ZGVcN4v__Z5add_2Pf" 379 // CHECK-DAG: "_ZGVdN4v__Z5add_2Pf" 380 // CHECK-DAG: "_ZGVeN8v__Z5add_2Pf" 381 382 // CHECK-DAG: "_ZGVbN2v__Z3food" 383 // CHECK-DAG: "_ZGVcN4v__Z3food" 384 // CHECK-DAG: "_ZGVdN4v__Z3food" 385 // CHECK-DAG: "_ZGVeN8v__Z3food" 386 387 // CHECK-DAG: "_ZGVbN2l__Z11constlineari" 388 // CHECK-DAG: "_ZGVcN4l__Z11constlineari" 389 // CHECK-DAG: "_ZGVdN4l__Z11constlineari" 390 // CHECK-DAG: "_ZGVeN8l__Z11constlineari" 391 392 // CHECK-DAG: "_ZGVbM4L2l16l8Ll4l__Z3OneRiPiiS_S0_i" 393 // CHECK-DAG: "_ZGVbN4L2l16l8Ll4l__Z3OneRiPiiS_S0_i" 394 // CHECK-DAG: "_ZGVbM4L2l16l8Ll4l__Z3TwoRiPiiS_S0_i" 395 // CHECK-DAG: "_ZGVbN4L2l16l8Ll4l__Z3TwoRiPiiS_S0_i" 396 // CHECK-DAG: "_ZGVbM4U2U__Z5ThreeRiS_" 397 // CHECK-DAG: "_ZGVbN4U2U__Z5ThreeRiS_" 398 // CHECK-DAG: "_ZGVbM4R8R4__Z4FourRiS_" 399 // CHECK-DAG: "_ZGVbN4R8R4__Z4FourRiS_" 400 // CHECK-DAG: "_ZGVbM4uL2Ls0L4Ls0U8Us0R32Rs0__Z4FiveiRsS_S_S_S_S_S_S_" 401 // CHECK-DAG: "_ZGVbN4uL2Ls0L4Ls0U8Us0R32Rs0__Z4FiveiRsS_S_S_S_S_S_S_" 402 403 // CHECK-NOT: "_ZGV{{.+}}__Z1fRA_i 404 405 #endif 406