2016-12-21 Vladimir Makarov <vmakarov@redhat.com>
[official-gcc.git] / gcc / testsuite / gcc.target / i386 / l_fma_float_2.c
blobce4efe92f79fa25dfcad7d86c3d63b964639c5cb
1 /* { dg-do compile } */
2 /* { dg-options "-O3 -Wno-attributes -mfpmath=sse -mfma -mtune=generic -mno-fma4" } */
4 /* Test that the compiler properly optimizes floating point multiply
5 and add instructions into FMA3 instructions. */
7 #define TYPE float
9 #include "l_fma_2.h"
11 /* { dg-final { scan-assembler-times "vfmadd\[123\]+ps" 8 } } */
12 /* { dg-final { scan-assembler-times "vfmsub\[123\]+ps" 8 } } */
13 /* { dg-final { scan-assembler-times "vfnmadd\[123\]+ps" 8 } } */
14 /* { dg-final { scan-assembler-times "vfnmsub\[123\]+ps" 8 } } */
15 /* { dg-final { scan-assembler-times "vfmadd\[123\]+ss" 176 } } */
16 /* { dg-final { scan-assembler-times "vfmsub\[123\]+ss" 176 } } */
17 /* { dg-final { scan-assembler-times "vfnmadd\[123\]+ss" 176 } } */
18 /* { dg-final { scan-assembler-times "vfnmsub\[123\]+ss" 176 } } */