diff options
author | Xi Ruoyao <xry111@xry111.site> | 2022-08-16 15:34:36 +0800 |
---|---|---|
committer | Xi Ruoyao <xry111@xry111.site> | 2022-08-17 16:08:05 +0800 |
commit | 3cab897a67af120aa18efa7ddd7ee49b9a29e5dd (patch) | |
tree | b4e16fddf5234b3fd5e61c1a3980b736259878a5 /libgomp/testsuite/libgomp.c | |
parent | 80f78716c2c7ce1b7f96077c35c1dd474a2086a2 (diff) | |
download | gcc-3cab897a67af120aa18efa7ddd7ee49b9a29e5dd.zip gcc-3cab897a67af120aa18efa7ddd7ee49b9a29e5dd.tar.gz gcc-3cab897a67af120aa18efa7ddd7ee49b9a29e5dd.tar.bz2 |
LoongArch: Provide fmin/fmax RTL pattern
We already had smin/smax RTL pattern using fmin/fmax instruction. But
for smin/smax, it's unspecified what will happen if either operand is
NaN. So we would generate calls to libc fmin/fmax functions with
-fno-finite-math-only (the default for all optimization levels expect
-Ofast).
But, LoongArch fmin/fmax instruction is IEEE-754-2008 conformant so we
can also use the instruction for fmin/fmax pattern and avoid the library
function call.
gcc/ChangeLog:
* config/loongarch/loongarch.md (fmax<mode>3): New RTL pattern.
(fmin<mode>3): Likewise.
gcc/testsuite/ChangeLog:
* gcc.target/loongarch/fmax-fmin.c: New test.
Diffstat (limited to 'libgomp/testsuite/libgomp.c')
0 files changed, 0 insertions, 0 deletions