1 /* { dg-do compile } */
2 /* { dg-options "-O3" } */
3 
4 /*
5 ** f11:
6 ** ...
7 ** 	ld1d	z0.d, p0/z, \[x1, x2, lsl 3\]
8 ** 	fcmgt	p2.d, p3/z, z0.d, #0.0
9 ** 	fcmgt	p1.d, p0/z, z0.d, #0.0
10 ** 	not	p1.b, p0/z, p1.b
11 ** 	ld1d	z1.d, p1/z, \[x3, x2, lsl 3\]
12 ** ...
13 */
14 
f11(double * restrict z,double * restrict w,double * restrict x,double * restrict y,int n)15 void f11(double * restrict z, double * restrict w, double * restrict x, double * restrict y, int n)
16 {
17     for (int i = 0; i < n; i++) {
18         z[i] = (w[i] > 0) ? w[i] : y[i];
19     }
20 }
21 
22 /* { dg-final { scan-assembler-not {\tbic\t} } } */
23 /* { dg-final { scan-assembler-times {\tnot\tp[0-9]+\.b, p[0-9]+/z, p[0-9]+\.b\n} 1 } } */
24 /* { dg-final { scan-assembler-times {\tfcmgt\tp[0-9]+\.d, p[0-9]+/z, z[0-9]+\.d, #0.0} 1 } } */
25