1 // PR middle-end/78025
2 // { dg-do compile }
3 // { dg-additional-options "-O2" }
4
5 struct S { S (); ~S (); };
6
7 int bar1 (int, int, float &, S &, int *, int, int &, int &, int &, int &, int &);
8 int bar2 (int, int, float &, S &, int *, int, int &, int &, int &, int &, int &);
9 int bar3 (int, int, float &, S &, int *, int, int &, int &, int &, int &, int &) __attribute__((noreturn));
10 int bar4 (int, int, float &, S &, int *, int, int &, int &, int &, int &, int &) __attribute__((noreturn));
11
12 #pragma omp declare simd notinbranch uniform (b, c, d, e) aligned (e : 16) \
13 linear (f : 2) linear (ref (g) : 1) \
14 linear (val (h) : 1) linear (uval (i) : 1) \
15 linear (k : 4)
16 int
foo1(int a,int b,float c,S d,int * e,int f,int & g,int & h,int & i,int j,int k)17 foo1 (int a, int b, float c, S d, int *e, int f, int &g, int &h, int &i, int j, int k)
18 {
19 return bar1 (a, b, c, d, e, f, g, h, i, j, k);
20 }
21 // { dg-warning "GCC does not currently support mixed size types for 'simd' functions" "" { target aarch64*-*-* } .-4 }
22
23 #pragma omp declare simd inbranch uniform (b, c, d, e) aligned (e : 16) \
24 linear (f : 2) linear (ref (g) : 1) \
25 linear (val (h) : 1) linear (uval (i) : 1) \
26 linear (k : 4)
27 int
foo2(int a,int b,float c,S d,int * e,int f,int & g,int & h,int & i,int j,int k)28 foo2 (int a, int b, float c, S d, int *e, int f, int &g, int &h, int &i, int j, int k)
29 {
30 return bar2 (a, b, c, d, e, f, g, h, i, j, k);
31 }
32 // { dg-warning "GCC does not currently support mixed size types for 'simd' functions" "" { target aarch64*-*-* } .-4 }
33
34 #pragma omp declare simd notinbranch uniform (b, c, d, e) aligned (e : 16) \
35 linear (f : 2) linear (ref (g) : 1) \
36 linear (val (h) : 1) linear (uval (i) : 1) \
37 linear (k : 4)
38 int
foo3(int a,int b,float c,S d,int * e,int f,int & g,int & h,int & i,int j,int k)39 foo3 (int a, int b, float c, S d, int *e, int f, int &g, int &h, int &i, int j, int k)
40 {
41 return bar3 (a, b, c, d, e, f, g, h, i, j, k);
42 }
43 // { dg-warning "GCC does not currently support mixed size types for 'simd' functions" "" { target aarch64*-*-* } .-4 }
44
45 #pragma omp declare simd inbranch uniform (b, c, d, e) aligned (e : 16) \
46 linear (f : 2) linear (ref (g) : 1) \
47 linear (val (h) : 1) linear (uval (i) : 1) \
48 linear (k : 4)
49 int
foo4(int a,int b,float c,S d,int * e,int f,int & g,int & h,int & i,int j,int k)50 foo4 (int a, int b, float c, S d, int *e, int f, int &g, int &h, int &i, int j, int k)
51 {
52 return bar4 (a, b, c, d, e, f, g, h, i, j, k);
53 }
54 // { dg-warning "GCC does not currently support mixed size types for 'simd' functions" "" { target aarch64*-*-* } .-4 }
55