Hi, Gentle ping:
https://gcc.gnu.org/pipermail/gcc-patches/2024-June/653376.html BR, Kewen on 2024/6/3 11:01, Kewen Lin wrote: > This is to remove macros {FLOAT,{,LONG_}DOUBLE}_TYPE_SIZE > defines in rl78 port, and add new port specific hook > implementation rl78_c_mode_for_floating_type. > > gcc/ChangeLog: > > * config/rl78/rl78.cc (TARGET_C_MODE_FOR_FLOATING_TYPE): New macro. > (rl78_c_mode_for_floating_type): New function. > * config/rl78/rl78.h (FLOAT_TYPE_SIZE): Remove. > (DOUBLE_TYPE_SIZE): Likewise. > (LONG_DOUBLE_TYPE_SIZE): Likewise. > --- > gcc/config/rl78/rl78.cc | 15 +++++++++++++++ > gcc/config/rl78/rl78.h | 4 ---- > 2 files changed, 15 insertions(+), 4 deletions(-) > > diff --git a/gcc/config/rl78/rl78.cc b/gcc/config/rl78/rl78.cc > index e5345bfa9dd..ccb1c4f3867 100644 > --- a/gcc/config/rl78/rl78.cc > +++ b/gcc/config/rl78/rl78.cc > @@ -4971,6 +4971,21 @@ rl78_preferred_reload_class (rtx x ATTRIBUTE_UNUSED, > reg_class_t rclass) > return rclass; > } > > +#undef TARGET_C_MODE_FOR_FLOATING_TYPE > +#define TARGET_C_MODE_FOR_FLOATING_TYPE rl78_c_mode_for_floating_type > + > +/* Implement TARGET_C_MODE_FOR_FLOATING_TYPE. Return SFmode for > + TI_DOUBLE_TYPE which is for double type, go with the default > + one for the others. */ > + > +static machine_mode > +rl78_c_mode_for_floating_type (enum tree_index ti) > +{ > + if (ti == TI_DOUBLE_TYPE) > + return SFmode; > + return default_mode_for_floating_type (ti); > +} > + > > /* The strub runtime uses asms, and physical register allocation won't > deal with them, so disable it. */ > diff --git a/gcc/config/rl78/rl78.h b/gcc/config/rl78/rl78.h > index cfff98df6bc..a960aee3931 100644 > --- a/gcc/config/rl78/rl78.h > +++ b/gcc/config/rl78/rl78.h > @@ -113,10 +113,6 @@ > #define LONG_TYPE_SIZE 32 > #define LONG_LONG_TYPE_SIZE 64 > > -#define FLOAT_TYPE_SIZE 32 > -#define DOUBLE_TYPE_SIZE 32 /*64*/ > -#define LONG_DOUBLE_TYPE_SIZE 64 /*DOUBLE_TYPE_SIZE*/ > - > #define DEFAULT_SIGNED_CHAR 0 > > #define STRICT_ALIGNMENT 1