diff options
author | Martin Liska <mliska@suse.cz> | 2021-06-01 15:39:14 +0200 |
---|---|---|
committer | Martin Liska <mliska@suse.cz> | 2021-08-06 11:03:20 +0200 |
commit | 318113a961220c8da79d8d29619138827ccc69f1 (patch) | |
tree | b1665e4eb7e9f7314fcf2c213d90cb5a07964665 /gcc | |
parent | fd351c76c23187fdc74d9af6874a54e2e84c4d25 (diff) | |
download | gcc-318113a961220c8da79d8d29619138827ccc69f1.zip gcc-318113a961220c8da79d8d29619138827ccc69f1.tar.gz gcc-318113a961220c8da79d8d29619138827ccc69f1.tar.bz2 |
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.
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/config/rs6000/rs6000.c | 2 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/powerpc/pragma-optimize.c | 13 |
2 files changed, 15 insertions, 0 deletions
diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c index 2de5a96..5b1c06b 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 0000000..e8ba63a --- /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; +} |