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