Sure thing, the FP_RETURN only acts on ABI_xxx similar to below: #define FP_RETURN (UNITS_PER_FP_ARG == 0 ? GP_RETURN : FP_ARG_FIRST)
I add some test for rv32/64imac option but don't cover all test cases without f/d extension, will have a try and keep you posted. Pan -----Original Message----- From: Kito Cheng <kito.ch...@gmail.com> Sent: Friday, April 12, 2024 4:56 PM To: Li, Pan2 <pan2...@intel.com> Cc: juzhe.zh...@rivai.ai; gcc-patches <gcc-patches@gcc.gnu.org> Subject: Re: [PATCH v1] RISC-V: Bugfix ICE non-vector in TARGET_FUNCTION_VALUE_REGNO_P Does FP reg also need gurared with TARGET_HARD_FLOAT? could you try to compile that case without F? On Fri, Apr 12, 2024 at 2:19 PM Li, Pan2 <pan2...@intel.com> wrote: > > Committed, thanks Juzhe. > > > > Pan > > > > From: juzhe.zh...@rivai.ai <juzhe.zh...@rivai.ai> > Sent: Friday, April 12, 2024 2:11 PM > To: Li, Pan2 <pan2...@intel.com>; gcc-patches <gcc-patches@gcc.gnu.org> > Cc: kito.cheng <kito.ch...@gmail.com>; Li, Pan2 <pan2...@intel.com> > Subject: Re: [PATCH v1] RISC-V: Bugfix ICE non-vector in > TARGET_FUNCTION_VALUE_REGNO_P > > > > LGTM。 > > > > ________________________________ > > juzhe.zh...@rivai.ai > > > > From: pan2.li > > Date: 2024-04-12 14:08 > > To: gcc-patches > > CC: juzhe.zhong; kito.cheng; Pan Li > > Subject: [PATCH v1] RISC-V: Bugfix ICE non-vector in > TARGET_FUNCTION_VALUE_REGNO_P > > From: Pan Li <pan2...@intel.com> > > > > This patch would like to fix one ICE when vector is not enabled > > in hook TARGET_FUNCTION_VALUE_REGNO_P implementation. The vector > > regno is available if and only if the TARGET_VECTOR is true. The > > previous implement missed this condition and then result in ICE > > when rv64gc build option without vector. > > > > PR target/114639 > > > > The below test suite is passed for this patch. > > > > * The rv64gcv fully regression tests. > > * The rv64gc fully regression tests. > > > > gcc/ChangeLog: > > > > * config/riscv/riscv.cc (riscv_function_value_regno_p): Add > > TARGET_VECTOR predicate for V_RETURN regno. > > > > gcc/testsuite/ChangeLog: > > > > * gcc.target/riscv/pr114639-1.c: New test. > > * gcc.target/riscv/pr114639-2.c: New test. > > * gcc.target/riscv/pr114639-3.c: New test. > > * gcc.target/riscv/pr114639-4.c: New test. > > > > Signed-off-by: Pan Li <pan2...@intel.com> > > --- > > gcc/config/riscv/riscv.cc | 2 +- > > gcc/testsuite/gcc.target/riscv/pr114639-1.c | 11 +++++++++++ > > gcc/testsuite/gcc.target/riscv/pr114639-2.c | 11 +++++++++++ > > gcc/testsuite/gcc.target/riscv/pr114639-3.c | 11 +++++++++++ > > gcc/testsuite/gcc.target/riscv/pr114639-4.c | 11 +++++++++++ > > 5 files changed, 45 insertions(+), 1 deletion(-) > > create mode 100644 gcc/testsuite/gcc.target/riscv/pr114639-1.c > > create mode 100644 gcc/testsuite/gcc.target/riscv/pr114639-2.c > > create mode 100644 gcc/testsuite/gcc.target/riscv/pr114639-3.c > > create mode 100644 gcc/testsuite/gcc.target/riscv/pr114639-4.c > > > > diff --git a/gcc/config/riscv/riscv.cc b/gcc/config/riscv/riscv.cc > > index 91f017dd52a..e5f00806bb9 100644 > > --- a/gcc/config/riscv/riscv.cc > > +++ b/gcc/config/riscv/riscv.cc > > @@ -11008,7 +11008,7 @@ riscv_function_value_regno_p (const unsigned regno) > > if (FP_RETURN_FIRST <= regno && regno <= FP_RETURN_LAST) > > return true; > > - if (regno == V_RETURN) > > + if (TARGET_VECTOR && regno == V_RETURN) > > return true; > > return false; > > diff --git a/gcc/testsuite/gcc.target/riscv/pr114639-1.c > b/gcc/testsuite/gcc.target/riscv/pr114639-1.c > > new file mode 100644 > > index 00000000000..f41723193a4 > > --- /dev/null > > +++ b/gcc/testsuite/gcc.target/riscv/pr114639-1.c > > @@ -0,0 +1,11 @@ > > +/* Test that we do not have ice when compile */ > > +/* { dg-do compile } */ > > +/* { dg-options "-march=rv64gc -mabi=lp64d -std=gnu89 -O3" } */ > > + > > +g (a, b) {} > > + > > +f (xx) > > + void* xx; > > +{ > > + __builtin_apply ((void*)g, xx, 200); > > +} > > diff --git a/gcc/testsuite/gcc.target/riscv/pr114639-2.c > b/gcc/testsuite/gcc.target/riscv/pr114639-2.c > > new file mode 100644 > > index 00000000000..0c402c4b254 > > --- /dev/null > > +++ b/gcc/testsuite/gcc.target/riscv/pr114639-2.c > > @@ -0,0 +1,11 @@ > > +/* Test that we do not have ice when compile */ > > +/* { dg-do compile } */ > > +/* { dg-options "-march=rv64imac -mabi=lp64 -std=gnu89 -O3" } */ > > + > > +g (a, b) {} > > + > > +f (xx) > > + void* xx; > > +{ > > + __builtin_apply ((void*)g, xx, 200); > > +} > > diff --git a/gcc/testsuite/gcc.target/riscv/pr114639-3.c > b/gcc/testsuite/gcc.target/riscv/pr114639-3.c > > new file mode 100644 > > index 00000000000..ffb0d6d162d > > --- /dev/null > > +++ b/gcc/testsuite/gcc.target/riscv/pr114639-3.c > > @@ -0,0 +1,11 @@ > > +/* Test that we do not have ice when compile */ > > +/* { dg-do compile } */ > > +/* { dg-options "-march=rv32gc -mabi=ilp32d -std=gnu89 -O3" } */ > > + > > +g (a, b) {} > > + > > +f (xx) > > + void* xx; > > +{ > > + __builtin_apply ((void*)g, xx, 200); > > +} > > diff --git a/gcc/testsuite/gcc.target/riscv/pr114639-4.c > b/gcc/testsuite/gcc.target/riscv/pr114639-4.c > > new file mode 100644 > > index 00000000000..a6e229101ef > > --- /dev/null > > +++ b/gcc/testsuite/gcc.target/riscv/pr114639-4.c > > @@ -0,0 +1,11 @@ > > +/* Test that we do not have ice when compile */ > > +/* { dg-do compile } */ > > +/* { dg-options "-march=rv32imac -mabi=ilp32 -std=gnu89 -O3" } */ > > + > > +g (a, b) {} > > + > > +f (xx) > > + void* xx; > > +{ > > + __builtin_apply ((void*)g, xx, 200); > > +} > > -- > > 2.34.1 > > > >