(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
arm/
mve/
intrinsics/
vmlaldavaq_u16.c
       1  /* { dg-require-effective-target arm_v8_1m_mve_ok } */
       2  /* { dg-add-options arm_v8_1m_mve } */
       3  /* { dg-additional-options "-O2" } */
       4  /* { dg-final { check-function-bodies "**" "" } } */
       5  
       6  #include "arm_mve.h"
       7  
       8  #ifdef __cplusplus
       9  extern "C" {
      10  #endif
      11  
      12  /*
      13  **foo:
      14  **	...
      15  **	vmlaldava.u16	(?:ip|fp|r[0-9]+), (?:ip|fp|r[0-9]+), q[0-9]+, q[0-9]+(?:	@.*|)
      16  **	...
      17  */
      18  uint64_t
      19  foo (uint64_t add, uint16x8_t m1, uint16x8_t m2)
      20  {
      21    return vmlaldavaq_u16 (add, m1, m2);
      22  }
      23  
      24  
      25  /*
      26  **foo1:
      27  **	...
      28  **	vmlaldava.u16	(?:ip|fp|r[0-9]+), (?:ip|fp|r[0-9]+), q[0-9]+, q[0-9]+(?:	@.*|)
      29  **	...
      30  */
      31  uint64_t
      32  foo1 (uint64_t add, uint16x8_t m1, uint16x8_t m2)
      33  {
      34    return vmlaldavaq (add, m1, m2);
      35  }
      36  
      37  /*
      38  **foo2:
      39  **	...
      40  **	vmlaldava.u16	(?:ip|fp|r[0-9]+), (?:ip|fp|r[0-9]+), q[0-9]+, q[0-9]+(?:	@.*|)
      41  **	...
      42  */
      43  uint64_t
      44  foo2 (uint16x8_t m1, uint16x8_t m2)
      45  {
      46    return vmlaldavaq (1, m1, m2);
      47  }
      48  
      49  #ifdef __cplusplus
      50  }
      51  #endif
      52  
      53  /* { dg-final { scan-assembler-not "__ARM_undef" } } */