[committed,nvptx] Limit HFmode support to mexperimental
Commit Message
Hi,
With PR104489 still open and end-of-stage-4 approaching, classify HFmode
support as experimental, which is not enabled by default but can be enabled
using -mexperimental.
This fixes the nvptx build when the default sm_xx is set to sm_53 or higher.
Note that we're not using -mfp16 or some such, because that might create
expectations about being able to switch support on or off in the future, and
at this point it's not clear why, once reaching non-experimental status, it
shouldn't always be enabled.
Committed to trunk.
Thanks,
- Tom
[nvptx] Limit HFmode support to mexperimental
gcc/ChangeLog:
2022-03-19 Tom de Vries <tdevries@suse.de>
* config/nvptx/nvptx.cc (nvptx_scalar_mode_supported_p)
(nvptx_libgcc_floating_mode_supported_p): Only enable HFmode for
mexperimental.
gcc/testsuite/ChangeLog:
2022-03-19 Tom de Vries <tdevries@suse.de>
* gcc.target/nvptx/float16-1.c: Add additional-options -mexperimental.
* gcc.target/nvptx/float16-2.c: Same.
* gcc.target/nvptx/float16-3.c: Same.
* gcc.target/nvptx/float16-4.c: Same.
* gcc.target/nvptx/float16-5.c: Same.
* gcc.target/nvptx/float16-6.c: Same.
---
gcc/config/nvptx/nvptx.cc | 4 ++--
gcc/testsuite/gcc.target/nvptx/float16-1.c | 1 +
gcc/testsuite/gcc.target/nvptx/float16-2.c | 1 +
gcc/testsuite/gcc.target/nvptx/float16-3.c | 1 +
gcc/testsuite/gcc.target/nvptx/float16-4.c | 1 +
gcc/testsuite/gcc.target/nvptx/float16-5.c | 1 +
gcc/testsuite/gcc.target/nvptx/float16-6.c | 1 +
7 files changed, 8 insertions(+), 2 deletions(-)
@@ -7156,7 +7156,7 @@ nvptx_cannot_force_const_mem (machine_mode mode ATTRIBUTE_UNUSED,
static bool
nvptx_scalar_mode_supported_p (scalar_mode mode)
{
- if (mode == HFmode && TARGET_SM53)
+ if (nvptx_experimental && mode == HFmode && TARGET_SM53)
return true;
return default_scalar_mode_supported_p (mode);
@@ -7165,7 +7165,7 @@ nvptx_scalar_mode_supported_p (scalar_mode mode)
static bool
nvptx_libgcc_floating_mode_supported_p (scalar_float_mode mode)
{
- if (mode == HFmode && TARGET_SM53)
+ if (nvptx_experimental && mode == HFmode && TARGET_SM53)
return true;
return default_libgcc_floating_mode_supported_p (mode);
@@ -1,5 +1,6 @@
/* { dg-do compile } */
/* { dg-options "-O2 -ffast-math -misa=sm_53 -mptx=_" } */
+/* { dg-additional-options "-mexperimental" } */
_Float16 var;
@@ -1,5 +1,6 @@
/* { dg-do compile } */
/* { dg-options "-O2 -ffast-math -misa=sm_80 -mptx=_" } */
+/* { dg-additional-options "-mexperimental" } */
_Float16 x;
_Float16 y;
@@ -1,5 +1,6 @@
/* { dg-do compile } */
/* { dg-options "-O2 -misa=sm_53 -mptx=_" } */
+/* { dg-additional-options "-mexperimental" } */
_Float16 var;
@@ -1,5 +1,6 @@
/* { dg-do compile } */
/* { dg-options "-O2 -ffast-math -misa=sm_53 -mptx=_" } */
+/* { dg-additional-options "-mexperimental" } */
_Float16 var;
@@ -1,5 +1,6 @@
/* { dg-do compile } */
/* { dg-options "-O2 -ffast-math -misa=sm_53 -mptx=_" } */
+/* { dg-additional-options "-mexperimental" } */
_Float16 a;
_Float16 b;
@@ -1,5 +1,6 @@
/* { dg-do compile } */
/* { dg-options "-O2 -misa=sm_53 -mptx=_" } */
+/* { dg-additional-options "-mexperimental" } */
_Float16 x;
_Float16 y;