Kewen Lin <li...@linux.ibm.com> 于2024年6月3日周一 11:03写道: > > This is to add new port specific hook implementation > mips_c_mode_for_floating_type, remove macros FLOAT_TYPE_SIZE > and DOUBLE_TYPE_SIZE, rename LONG_DOUBLE_TYPE_SIZE to > MIPS_LONG_DOUBLE_TYPE_SIZE since we poison LONG_DOUBLE_TYPE_SIZE > but some subtarget wants to redefine it and some macro defines > need it. >
Good for me if the framework is approved. > gcc/ChangeLog: > > * config/mips/mips.cc (mips_c_mode_for_floating_type): New function. > (TARGET_C_MODE_FOR_FLOATING_TYPE): New macro. > * config/mips/mips.h (UNITS_PER_FPVALUE): Replace > LONG_DOUBLE_TYPE_SIZE > with MIPS_LONG_DOUBLE_TYPE_SIZE. > (MAX_FIXED_MODE_SIZE): Likewise. > (STRUCTURE_SIZE_BOUNDARY): Likewise. > (BIGGEST_ALIGNMENT): Likewise. > (FLOAT_TYPE_SIZE): Remove. > (DOUBLE_TYPE_SIZE): Remove. > (LONG_DOUBLE_TYPE_SIZE): Rename to ... > (MIPS_LONG_DOUBLE_TYPE_SIZE): ... this. > * config/mips/n32-elf.h (LONG_DOUBLE_TYPE_SIZE): Rename to ... > (MIPS_LONG_DOUBLE_TYPE_SIZE): ... this. > --- > gcc/config/mips/mips.cc | 14 ++++++++++++++ > gcc/config/mips/mips.h | 13 ++++++------- > gcc/config/mips/n32-elf.h | 4 ++-- > 3 files changed, 22 insertions(+), 9 deletions(-) > > diff --git a/gcc/config/mips/mips.cc b/gcc/config/mips/mips.cc > index b63d40a357b..3e5035a385c 100644 > --- a/gcc/config/mips/mips.cc > +++ b/gcc/config/mips/mips.cc > @@ -22972,6 +22972,18 @@ mips_asm_file_end (void) > file_end_indicate_exec_stack (); > } > > +/* Implement TARGET_C_MODE_FOR_FLOATING_TYPE. Return TFmode or DFmode > + for TI_LONG_DOUBLE_TYPE which is for long double type, go with the > + default one for the others. */ > + > +static machine_mode > +mips_c_mode_for_floating_type (enum tree_index ti) > +{ > + if (ti == TI_LONG_DOUBLE_TYPE) > + return MIPS_LONG_DOUBLE_TYPE_SIZE == 64 ? DFmode : TFmode; > + return default_mode_for_floating_type (ti); > +} > + > void > mips_bit_clear_info (enum machine_mode mode, unsigned HOST_WIDE_INT m, > int *start_pos, int *size) > @@ -23340,6 +23352,8 @@ mips_bit_clear_p (enum machine_mode mode, unsigned > HOST_WIDE_INT m) > #undef TARGET_ASM_FILE_END > #define TARGET_ASM_FILE_END mips_asm_file_end > > +#undef TARGET_C_MODE_FOR_FLOATING_TYPE > +#define TARGET_C_MODE_FOR_FLOATING_TYPE mips_c_mode_for_floating_type > > struct gcc_target targetm = TARGET_INITIALIZER; > > diff --git a/gcc/config/mips/mips.h b/gcc/config/mips/mips.h > index 9d965966f2f..7a9b18c8096 100644 > --- a/gcc/config/mips/mips.h > +++ b/gcc/config/mips/mips.h > @@ -1654,7 +1654,7 @@ FP_ASM_SPEC "\ > #define UNITS_PER_FPVALUE \ > (TARGET_SOFT_FLOAT_ABI ? 0 \ > : TARGET_SINGLE_FLOAT ? UNITS_PER_FPREG \ > - : LONG_DOUBLE_TYPE_SIZE / BITS_PER_UNIT) > + : MIPS_LONG_DOUBLE_TYPE_SIZE / BITS_PER_UNIT) > > /* The number of bytes in a double. */ > #define UNITS_PER_DOUBLE (TYPE_PRECISION (double_type_node) / BITS_PER_UNIT) > @@ -1665,9 +1665,8 @@ FP_ASM_SPEC "\ > #define LONG_TYPE_SIZE (TARGET_LONG64 ? 64 : 32) > #define LONG_LONG_TYPE_SIZE 64 > > -#define FLOAT_TYPE_SIZE 32 > -#define DOUBLE_TYPE_SIZE 64 > -#define LONG_DOUBLE_TYPE_SIZE (TARGET_NEWABI ? 128 : 64) > +/* LONG_DOUBLE_TYPE_SIZE gets poisoned, so add MIPS_ prefix. */ > +#define MIPS_LONG_DOUBLE_TYPE_SIZE (TARGET_NEWABI ? 128 : 64) > > /* Define the sizes of fixed-point types. */ > #define SHORT_FRACT_TYPE_SIZE 8 > @@ -1684,7 +1683,7 @@ FP_ASM_SPEC "\ > > /* long double is not a fixed mode, but the idea is that, if we > support long double, we also want a 128-bit integer type. */ > -#define MAX_FIXED_MODE_SIZE LONG_DOUBLE_TYPE_SIZE > +#define MAX_FIXED_MODE_SIZE MIPS_LONG_DOUBLE_TYPE_SIZE > > /* Width in bits of a pointer. */ > #ifndef POINTER_SIZE > @@ -1705,10 +1704,10 @@ FP_ASM_SPEC "\ > #define STRUCTURE_SIZE_BOUNDARY 8 > > /* There is no point aligning anything to a rounder boundary than > - LONG_DOUBLE_TYPE_SIZE, unless under MSA the bigggest alignment is > + MIPS_LONG_DOUBLE_TYPE_SIZE, unless under MSA the bigggest alignment is > BITS_PER_MSA_REG. */ > #define BIGGEST_ALIGNMENT \ > - (ISA_HAS_MSA ? BITS_PER_MSA_REG : LONG_DOUBLE_TYPE_SIZE) > + (ISA_HAS_MSA ? BITS_PER_MSA_REG : MIPS_LONG_DOUBLE_TYPE_SIZE) > > /* All accesses must be aligned. */ > #define STRICT_ALIGNMENT (!ISA_HAS_UNALIGNED_ACCESS) > diff --git a/gcc/config/mips/n32-elf.h b/gcc/config/mips/n32-elf.h > index 94a90d847f0..01c8a852539 100644 > --- a/gcc/config/mips/n32-elf.h > +++ b/gcc/config/mips/n32-elf.h > @@ -26,5 +26,5 @@ along with GCC; see the file COPYING3. If not see > #define NO_DOLLAR_IN_LABEL > > /* Force n32 to use 64-bit long doubles. */ > -#undef LONG_DOUBLE_TYPE_SIZE > -#define LONG_DOUBLE_TYPE_SIZE 64 > +#undef MIPS_LONG_DOUBLE_TYPE_SIZE > +#define MIPS_LONG_DOUBLE_TYPE_SIZE 64 > -- > 2.43.0 >