1  /* { dg-do compile } */
       2  /* { dg-options "-O2 -msse2" } */
       3  
       4  typedef __bf16 v4bf __attribute__ ((vector_size (8)));
       5  typedef __bf16 v2bf __attribute__ ((vector_size (4)));
       6  
       7  v4bf
       8  v4bf_abi_1 (v4bf a)
       9  {
      10    return a;
      11  }
      12  
      13  v4bf
      14  v4bf_abi_3 (v4bf a, v4bf b, v4bf c)
      15  {
      16    return c;
      17  }
      18  
      19  /* { dg-final { scan-assembler-times "movq\[\\t \]*%mm2, %mm0" 1 { target ia32 } } } */
      20  /* { dg-final { scan-assembler-times "movaps\[\\t \]*%xmm2, %xmm0" 1 { target { ! ia32 } } } } */
      21  
      22  v4bf
      23  v4bf_abi_4 (v4bf a, v4bf b, v4bf c, v4bf d)
      24  {
      25    return d;
      26  }
      27  
      28  /* { dg-final { scan-assembler-times "movq\[\\t \]*4\\(%esp\\), %mm0" 1 { target ia32 } } } */
      29  /* { dg-final { scan-assembler-times "movaps\[\\t \]*%xmm3, %xmm0" 1 { target { ! ia32 } } } } */
      30  
      31  v2bf
      32  v2bf_test (v2bf a, v2bf b, v2bf c, v2bf d)
      33  {
      34    return b;
      35  }
      36  
      37  /* { dg-final { scan-assembler-times "movl\[\\t \]*8\\(%esp\\), %eax" 1 { target ia32 } } } */
      38  /* { dg-final { scan-assembler-times "movaps\[\\t \]*%xmm1, %xmm0" 1 { target { ! ia32 } } } } */