From: Martin Liska Date: Tue, 1 Jun 2021 13:39:14 +0000 (+0200) Subject: rs6000: Fix restored rs6000_long_double_type_size X-Git-Tag: basepoints/gcc-13~5534 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=318113a961220c8da79d8d29619138827ccc69f1;p=thirdparty%2Fgcc.git rs6000: Fix restored rs6000_long_double_type_size As mentioned in the "Fallout: save/restore target options in handle_optimize_attribute" thread, we need to support target option restore of rs6000_long_double_type_size == FLOAT_PRECISION_TFmode. gcc/ChangeLog: * config/rs6000/rs6000.c (rs6000_option_override_internal): When a target option is restored, it can have rs6000_long_double_type_size set to FLOAT_PRECISION_TFmode and error should not be emitted. gcc/testsuite/ChangeLog: * gcc.target/powerpc/pragma-optimize.c: New test. --- diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c index 2de5a96e1b6c..5b1c06b09fc0 100644 --- a/gcc/config/rs6000/rs6000.c +++ b/gcc/config/rs6000/rs6000.c @@ -4189,6 +4189,8 @@ rs6000_option_override_internal (bool global_init_p) else rs6000_long_double_type_size = default_long_double_size; } + else if (rs6000_long_double_type_size == FLOAT_PRECISION_TFmode) + ; /* The option value can be seen when cl_target_option_restore is called. */ else if (rs6000_long_double_type_size == 128) rs6000_long_double_type_size = FLOAT_PRECISION_TFmode; else if (global_options_set.x_rs6000_ieeequad) diff --git a/gcc/testsuite/gcc.target/powerpc/pragma-optimize.c b/gcc/testsuite/gcc.target/powerpc/pragma-optimize.c new file mode 100644 index 000000000000..e8ba63a0667d --- /dev/null +++ b/gcc/testsuite/gcc.target/powerpc/pragma-optimize.c @@ -0,0 +1,13 @@ +/* { dg-options "-O2 -mlong-double-128 -mabi=ibmlongdouble" } */ + +extern unsigned long int x; +extern float f (float); +extern __typeof (f) f_power8; +extern __typeof (f) f_power9; +extern __typeof (f) f __attribute__ ((ifunc ("f_ifunc"))); +static __attribute__ ((optimize (1))) __typeof (f) * +f_ifunc (void) +{ + __typeof (f) *res = x ? f_power9 : f_power8; + return res; +}