diff options
author | Georg-Johann Lay <avr@gjlay.de> | 2019-11-25 08:59:06 +0000 |
---|---|---|
committer | Georg-Johann Lay <gjl@gcc.gnu.org> | 2019-11-25 08:59:06 +0000 |
commit | 5b01f1a57cc90bcee58ccf75e6062748e1d66448 (patch) | |
tree | 475a122d85e5d17349e4a3f4b1e275531759ec55 /gcc/config | |
parent | f10d2d85c90c9c649675c248cd5a99f66288f81f (diff) | |
download | gcc-5b01f1a57cc90bcee58ccf75e6062748e1d66448.zip gcc-5b01f1a57cc90bcee58ccf75e6062748e1d66448.tar.gz gcc-5b01f1a57cc90bcee58ccf75e6062748e1d66448.tar.bz2 |
Build double32 / long-double32 multilibs if needed.
gcc/
Build double32 / long-double32 multilibs if needed.
PR target/92055
* config/avr/t-avr:
(HAVE_DOUBLE_MULTILIB, HAVE_LONG_DOUBLE_MULTILIB): Remove vars.
(HAVE_DOUBLE32, HAVE_LONG_DOUBLE32, WITH_LONG_DOUBLE)
(HAVE_DOUBLE64, HAVE_LONG_DOUBLE64, WITH_DOUBLE): Set from
tm_defines and pass to genmultilib.awk.
* config/avr/genmultilib.awk: Use these variables to add double32
and / or long-double32 multilib(s) as needed.
* config/avr/driver-avr.c (avr_double_lib): Adjust comment.
From-SVN: r278668
Diffstat (limited to 'gcc/config')
-rw-r--r-- | gcc/config/avr/driver-avr.c | 5 | ||||
-rw-r--r-- | gcc/config/avr/genmultilib.awk | 110 | ||||
-rw-r--r-- | gcc/config/avr/t-avr | 32 |
3 files changed, 107 insertions, 40 deletions
diff --git a/gcc/config/avr/driver-avr.c b/gcc/config/avr/driver-avr.c index a6239da..b007954 100644 --- a/gcc/config/avr/driver-avr.c +++ b/gcc/config/avr/driver-avr.c @@ -114,10 +114,7 @@ avr_devicespecs_file (int argc, const char **argv) /* Re-build the -mdouble= and -mlong-double= options. This is needed - because multilib selection is based on the physical presence of an - option on the command line, which is not the case for, say, when the - double=64 multilib is to be selected by --with-double=64 but the user - does not specify -mdouble=64 explicitly. */ + because these options are not independent of each other. */ const char* avr_double_lib (int argc, const char **argv) diff --git a/gcc/config/avr/genmultilib.awk b/gcc/config/avr/genmultilib.awk index 1228022..c1c82cf 100644 --- a/gcc/config/avr/genmultilib.awk +++ b/gcc/config/avr/genmultilib.awk @@ -38,12 +38,6 @@ BEGIN { dir_rcall = "short-calls" opt_rcall = "mshort-calls" - dir_double64 = "double64" - opt_double64 = "mdouble=64" - - dir_long_double64 = "long-double64" - opt_long_double64 = "mlong-double=64" - # awk Variable Makefile Variable # ------------------------------------------ # m_options <-> MULTILIB_OPTIONS @@ -56,8 +50,23 @@ BEGIN { m_required = "\nMULTILIB_REQUIRED =" m_reuse = "\nMULTILIB_REUSE =" - have_double_multi = (HAVE_DOUBLE_MULTILIB == "HAVE_DOUBLE_MULTILIB") - have_long_double_multi = (HAVE_LONG_DOUBLE_MULTILIB == "HAVE_LONG_DOUBLE_MULTILIB") + have_long_double_is_double = (HAVE_LONG_DOUBLE_IS_DOUBLE \ + == "HAVE_LONG_DOUBLE_IS_DOUBLE") + have_double32 = (HAVE_DOUBLE32 == "HAVE_DOUBLE32") + have_double64 = (HAVE_DOUBLE64 == "HAVE_DOUBLE64") + have_long_double32 = (HAVE_LONG_DOUBLE32 == "HAVE_LONG_DOUBLE32") + have_long_double64 = (HAVE_LONG_DOUBLE64 == "HAVE_LONG_DOUBLE64") + + have_double_multi = (have_double32 && have_double64) + have_long_double_multi = (! have_long_double_is_double \ + && have_long_double32 && have_long_double64) + + # How to switch away from the default. + dir_double = "double" (96 - with_double) + opt_double = "mdouble=" (96 - with_double) + + dir_long_double = "long-double" (96 - with_long_double) + opt_long_double = "mlong-double=" (96 - with_long_double) } ################################################################## @@ -86,6 +95,26 @@ BEGIN { # The first empty line stops copy-pasting the GPL comments # from this file to the generated file. + if (comment) + { + print + + if (have_double_multi) + { + print "# dir_double = " dir_double + print "# opt_double = -" opt_double + } + else + print "# No multilib for double." + + if (have_long_double_multi) + { + print "# dir_long_double = " dir_long_double + print "# opt_long_double = -" opt_long_double + } + else + print "# No multilib for long double." + } comment = 0 } @@ -145,21 +174,30 @@ BEGIN { m_required = m_required " \\\n\t" opts if (have_double_multi && have_long_double_multi) { - m_required = m_required " \\\n\t" opts "/" opt_double64 - m_required = m_required " \\\n\t" opts "/" opt_long_double64 - - # -mlong-double=64 -mdouble=64 is the same as -mdouble=64, - # hence add a respective reuse. - d_opts = opts "/" opt_double64 - d_reuse = opts "/" opt_double64 "/" opt_long_double64 - gsub (/=/, ".", d_opts) - gsub (/=/, ".", d_reuse) - m_reuse = m_reuse " \\\n\t" d_opts "=" d_reuse + m_required = m_required " \\\n\t" opts "/" opt_double + m_required = m_required " \\\n\t" opts "/" opt_long_double + + # We have only 3 different combinations because -mdouble=64 + # implies -mlong-double=64, and -mlong-double=32 implies + # -mdouble=32, hence add respective reuses. The reuse is + # not needed in the case with_double != with_long_double + # which means with_double=32 with_long_double=64 because + # the driver will rectify combining -mdouble=64 and + # -mlong-double=32. + if (with_double == with_long_double) + { + d_opts = with_double == 32 ? opt_double : opt_long_double + d_opts = opts "/" d_opts + d_reuse = opts "/" opt_double "/" opt_long_double + gsub (/=/, ".", d_opts) + gsub (/=/, ".", d_reuse) + m_reuse = m_reuse " \\\n\t" d_opts "=" d_reuse + } } else if (have_double_multi) - m_required = m_required " \\\n\t" opts "/" opt_double64 + m_required = m_required " \\\n\t" opts "/" opt_double else if (have_long_double_multi) - m_required = m_required " \\\n\t" opts "/" opt_long_double64 + m_required = m_required " \\\n\t" opts "/" opt_long_double } } } @@ -177,26 +215,34 @@ END { if (have_double_multi && have_long_double_multi) { - print m_options " " opt_tiny " " opt_rcall " " opt_double64 "/" opt_long_double64 - print m_dirnames " " dir_tiny " " dir_rcall " " dir_double64 " " dir_long_double64 - # Notice that the ./double64 and ./long-double64 variants cannot + print m_options " " opt_tiny " " opt_rcall " " opt_double "/" opt_long_double + print m_dirnames " " dir_tiny " " dir_rcall " " dir_double " " dir_long_double + # Notice that the ./double* and ./long-double* variants cannot # be copied by t-avrlibc because the . default multilib is built # after all the others. - m_required = m_required " \\\n\t" opt_double64 - m_required = m_required " \\\n\t" opt_long_double64 - m_reuse = m_reuse " \\\n\tmdouble.64=mdouble.64/mlong-double.64" + m_required = m_required " \\\n\t" opt_double + m_required = m_required " \\\n\t" opt_long_double + if (with_double == with_long_double) + { + d_opts = with_double == 32 ? opt_double : opt_long_double + d_reuse = opt_double "/" opt_long_double + gsub (/=/, ".", d_opts) + gsub (/=/, ".", d_reuse) + m_reuse = m_reuse " \\\n\t" d_opts "=" d_reuse + + } } else if (have_double_multi) { - print m_options " " opt_tiny " " opt_rcall " " opt_double64 - print m_dirnames " " dir_tiny " " dir_rcall " " dir_double64 - m_required = m_required " \\\n\t" opt_double64 + print m_options " " opt_tiny " " opt_rcall " " opt_double + print m_dirnames " " dir_tiny " " dir_rcall " " dir_double + m_required = m_required " \\\n\t" opt_double } else if (have_long_double_multi) { - print m_options " " opt_tiny " " opt_rcall " " opt_long_double64 - print m_dirnames " " dir_tiny " " dir_rcall " " dir_long_double64 - m_required = m_required " \\\n\t" opt_long_double64 + print m_options " " opt_tiny " " opt_rcall " " opt_long_double + print m_dirnames " " dir_tiny " " dir_rcall " " dir_long_double + m_required = m_required " \\\n\t" opt_long_double } else { diff --git a/gcc/config/avr/t-avr b/gcc/config/avr/t-avr index 5384af4..f87a5e6 100644 --- a/gcc/config/avr/t-avr +++ b/gcc/config/avr/t-avr @@ -16,8 +16,27 @@ # along with GCC; see the file COPYING3. If not see # <http://www.gnu.org/licenses/>. -HAVE_DOUBLE_MULTILIB = $(findstring HAVE_DOUBLE_MULTILIB, $(tm_defines)) -HAVE_LONG_DOUBLE_MULTILIB = $(findstring HAVE_LONG_DOUBLE_MULTILIB, $(tm_defines)) +HAVE_DOUBLE32 = $(findstring HAVE_DOUBLE32, $(tm_defines)) +HAVE_DOUBLE64 = $(findstring HAVE_DOUBLE64, $(tm_defines)) +HAVE_LONG_DOUBLE32 = $(findstring HAVE_LONG_DOUBLE32, $(tm_defines)) +HAVE_LONG_DOUBLE64 = $(findstring HAVE_LONG_DOUBLE64, $(tm_defines)) +HAVE_LONG_DOUBLE_IS_DOUBLE = $(findstring HAVE_LONG_DOUBLE_IS_DOUBLE, $(tm_defines)) + +ifeq (WITH_DOUBLE32, $(findstring WITH_DOUBLE32, $(tm_defines))) +WITH_DOUBLE=32 +endif + +ifeq (WITH_DOUBLE64, $(findstring WITH_DOUBLE64, $(tm_defines))) +WITH_DOUBLE=64 +endif + +ifeq (WITH_LONG_DOUBLE32, $(findstring WITH_LONG_DOUBLE32, $(tm_defines))) +WITH_LONG_DOUBLE=32 +endif + +ifeq (WITH_LONG_DOUBLE64, $(findstring WITH_LONG_DOUBLE64, $(tm_defines))) +WITH_LONG_DOUBLE=64 +endif PASSES_EXTRA += $(srcdir)/config/avr/avr-passes.def @@ -101,8 +120,13 @@ multilib.h Makefile s-mlib: t-multilib-avr t-multilib-avr: $(srcdir)/config/avr/genmultilib.awk \ $(AVR_MCUS) - $(AWK) -v HAVE_DOUBLE_MULTILIB=$(HAVE_DOUBLE_MULTILIB) \ - -v HAVE_LONG_DOUBLE_MULTILIB=$(HAVE_LONG_DOUBLE_MULTILIB) \ + $(AWK) -v HAVE_LONG_DOUBLE_IS_DOUBLE=$(HAVE_LONG_DOUBLE_IS_DOUBLE) \ + -v HAVE_DOUBLE32=$(HAVE_DOUBLE32) \ + -v HAVE_DOUBLE64=$(HAVE_DOUBLE64) \ + -v HAVE_LONG_DOUBLE32=$(HAVE_LONG_DOUBLE32) \ + -v HAVE_LONG_DOUBLE64=$(HAVE_LONG_DOUBLE64) \ + -v with_double=$(WITH_DOUBLE) \ + -v with_long_double=$(WITH_LONG_DOUBLE) \ -f $< $< $(AVR_MCUS) > $@ include t-multilib-avr |