1 /* { dg-require-effective-target arm_v8_1m_mve_ok } */
2 /* { dg-add-options arm_v8_1m_mve } */
3 /* { dg-additional-options "-O2" } */
4
5 #include "arm_mve.h"
6
7 uint32_t
foo(uint32_t a,uint16x8_t b,uint16x8_t c,mve_pred16_t p)8 foo (uint32_t a, uint16x8_t b, uint16x8_t c, mve_pred16_t p)
9 {
10 return vmladavaq_p_u16 (a, b, c, p);
11 }
12
13 /* { dg-final { scan-assembler "vmladavat.u16" } } */
14
15 uint32_t
foo1(uint32_t a,uint16x8_t b,uint16x8_t c,mve_pred16_t p)16 foo1 (uint32_t a, uint16x8_t b, uint16x8_t c, mve_pred16_t p)
17 {
18 return vmladavaq_p (a, b, c, p);
19 }
20
21 /* { dg-final { scan-assembler "vmladavat.u16" } } */
22 /* { dg-final { scan-assembler "vmladavat.u16" } } */
23