1 /* { dg-do compile { target aarch64*-*-* } } */
2 /* { dg-options "-O2 -march=armv8.2-a+sve -msve-vector-bits=256" } */
3 
4 #include <stdint.h>
5 
6 typedef int8_t vnx16qi __attribute__((vector_size(32)));
7 
8 vnx16qi
foo(vnx16qi x,vnx16qi y)9 foo (vnx16qi x, vnx16qi y)
10 {
11   return (vnx16qi) { -1, 0, 0, -1, -1, -1, 0, 0,
12 		     -1, -1, -1, -1, 0, 0, 0, 0,
13 		     -1, -1, -1, -1, -1, -1, -1, -1,
14 		     0, 0, 0, 0, 0, 0, 0, 0 } ? x : y;
15 }
16 
17 /* { dg-final { scan-assembler {\tldr\tp[0-9]+,} } } */
18 /* { dg-final { scan-assembler {\t\.byte\t57\n\t\.byte\t15\n\t\.byte\t(255|-1)\n\t\.byte\t0\n} } } */
19