diff options
author | Alan Modra <amodra@gmail.com> | 2016-09-29 07:31:48 +0930 |
---|---|---|
committer | Alan Modra <amodra@gcc.gnu.org> | 2016-09-29 07:31:48 +0930 |
commit | e9dda04f0760e78c5834b1beddab39cd562ad7c1 (patch) | |
tree | 7d561e18cf4ecf2d793c4c34f392eac627e6209d /gcc/config.in | |
parent | 91eaca5e32abab6179fba0e2543daf1cc1f64bde (diff) | |
download | gcc-e9dda04f0760e78c5834b1beddab39cd562ad7c1.zip gcc-e9dda04f0760e78c5834b1beddab39cd562ad7c1.tar.gz gcc-e9dda04f0760e78c5834b1beddab39cd562ad7c1.tar.bz2 |
[RS6000] .gnu.attributes Tag_GNU_Power_ABI_FP
Extend this attribute to cover long double ABIs, for 64-bit too.
This patch also corrects an error that crept in to code setting
rs6000_passes_float. See the added comment. Passing IEEE128 values
in vsx regs ought to set both Tag_GNU_Power_ABI_FP and
Tag_GNU_Power_ABI_Vector. Also adds a new option, default on, that
disables output of .gnu_attribute assembly directives.
* config/rs6000/sysv4.opt (mgnu-attribute): New option.
* doc/invoke.texi: Document it.
* config/rs6000/rs6000.c (HAVE_LD_PPC_GNU_ATTR_LONG_DOUBLE): Define.
(rs6000_passes_float): Comment.
(rs6000_passes_long_double): New static var.
(call_ABI_of_interest): Return false unless rs6000_gnu_attr is set.
(init_cumulative_args): Set up to emit fp .gnu_attribute for
ELF 64-bit ABIs as well as 32-bit ELF. Correct rs6000_passes_float
to include fp values returned in vectors.
Set rs6000_passes_long_double.
(rs6000_function_arg_advance_1): Likewise for function args.
(rs6000_elf_file_end): Emit fp .gnu_attribute for ELF 64-bit ABIs,
and SPE. Emit long double tag value too.
(rs6000_opt_vars): Add gnu-attr.
* configure.ac (HAVE_LD_PPC_GNU_ATTR_LONG_DOUBLE): New ppc32 test.
* configure: Regenerate.
* config.in: Regenerate.
From-SVN: r240601
Diffstat (limited to 'gcc/config.in')
-rw-r--r-- | gcc/config.in | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/gcc/config.in b/gcc/config.in index a736de3..8470456 100644 --- a/gcc/config.in +++ b/gcc/config.in @@ -1538,6 +1538,12 @@ #endif +/* Define if your PowerPC linker has .gnu.attributes long double support. */ +#ifndef USED_FOR_TARGET +#undef HAVE_LD_PPC_GNU_ATTR_LONG_DOUBLE +#endif + + /* Define if your linker supports --push-state/--pop-state */ #ifndef USED_FOR_TARGET #undef HAVE_LD_PUSHPOPSTATE_SUPPORT |