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 uint32x4_t
foo(uint16_t const * base,uint32x4_t offset,mve_pred16_t p)8 foo (uint16_t const * base, uint32x4_t offset, mve_pred16_t p)
9 {
10   return vldrhq_gather_offset_z_u32 (base, offset, p);
11 }
12 
13 /* { dg-final { scan-assembler "vldrht.u32"  }  } */
14 
15 uint32x4_t
foo1(uint16_t const * base,uint32x4_t offset,mve_pred16_t p)16 foo1 (uint16_t const * base, uint32x4_t offset, mve_pred16_t p)
17 {
18   return vldrhq_gather_offset_z (base, offset, p);
19 }
20 
21 /* { dg-final { scan-assembler "vldrht.u32"  }  } */
22