blob: a59862cf9c3476372e5b631fb66b7993ac4e25a3 [file] [log] [blame]
/* { dg-do compile } */
/* { dg-options "-O2 -msve-vector-bits=256" } */
#include <stdint.h>
typedef int32_t vnx4si __attribute__((vector_size(32)));
void
foo (int32_t val)
{
register vnx4si x asm ("z0");
register vnx4si y asm ("z0");
asm volatile ("" : "=w" (y));
val += 1;
vnx4si z = { val, val, val, val, val, val, val, val };
x = (vnx4si) { -1, 0, 0, -1, 0, -1, 0, -1 } ? z : y;
asm volatile ("" :: "w" (x));
}
/* { dg-final { scan-assembler {\tmov\tz0\.s, p[0-7]/m, w[0-9]+\n} } } */
/* { dg-final { scan-assembler-not {\tmovprfx\t} } } */