diff --git a/gcc/config.gcc b/gcc/config.gcc index 005301338..382788734 100644 --- a/gcc/config.gcc +++ b/gcc/config.gcc @@ -4129,6 +4129,58 @@ case "${target}" in exit 1 ;; esac + + # Handle --with-multilib-list. + if test "x${with_multilib_list}" != xdefault; then + tm_file="${tm_file} riscv/withmultilib.h" + tmake_file="${tmake_file} riscv/t-withmultilib" + + case ${with_multilib_list} in + ilp32 | ilp32f | ilp32d \ + | lp64 | lp64f | lp64d ) + TM_MULTILIB_CONFIG="${with_arch},${with_multilib_list}" + ;; + *) + echo "--with-multilib-list=${with_multilib_list} not supported." + exit 1 + esac + + # Define macros to select the default multilib. + case ${with_arch} in + rv32gc) + tm_defines="${tm_defines} TARGET_MLIB_ARCH=1" + ;; + rv64gc) + tm_defines="${tm_defines} TARGET_MLIB_ARCH=2" + ;; + *) + echo "unsupported --with-arch for --with-multilib-list" + exit 1 + esac + case ${with_abi} in + ilp32) + tm_defines="${tm_defines} TARGET_MLIB_ABI=1" + ;; + ilp32f) + tm_defines="${tm_defines} TARGET_MLIB_ABI=2" + ;; + ilp32d) + tm_defines="${tm_defines} TARGET_MLIB_ABI=3" + ;; + lp64) + tm_defines="${tm_defines} TARGET_MLIB_ABI=4" + ;; + lp64f) + tm_defines="${tm_defines} TARGET_MLIB_ABI=5" + ;; + lp64d) + tm_defines="${tm_defines} TARGET_MLIB_ABI=6" + ;; + *) + echo "unsupported --with-abi for --with-multilib" + exit 1 + esac + fi ;; mips*-*-*) diff --git a/gcc/config/riscv/t-withmultilib b/gcc/config/riscv/t-withmultilib new file mode 100644 index 000000000..bcd0845b4 --- /dev/null +++ b/gcc/config/riscv/t-withmultilib @@ -0,0 +1,6 @@ +comma=, +MULTILIB_OPTIONS = $(subst lp64,mabi=lp64,$(subst ilp32,mabi=ilp32,$(subst rv,march=rv,$(subst $(comma), ,$(TM_MULTILIB_CONFIG))))) +MULTILIB_DIRNAMES = $(patsubst rv32%,lib32,$(patsubst rv64%,lib64,$(subst $(comma), ,$(TM_MULTILIB_CONFIG)))) +MULTILIB_OSDIRNAMES = $(subst lib,../lib,$(MULTILIB_DIRNAMES)) +MULTILIB_REQUIRED = $(subst lp64,mabi=lp64,$(subst ilp32,mabi=ilp32,$(subst rv,march=rv,$(subst $(comma),/,$(TM_MULTILIB_CONFIG))))) +MULTILIB_REUSE = diff --git a/gcc/config/riscv/withmultilib.h b/gcc/config/riscv/withmultilib.h new file mode 100644 index 000000000..d703147fa --- /dev/null +++ b/gcc/config/riscv/withmultilib.h @@ -0,0 +1,51 @@ +/* MULTILIB_DEFAULTS definitions for --with-multilib-list. + Copyright (C) 2018 Free Software Foundation, Inc. + + This file is part of GCC. + + GCC is free software; you can redistribute it and/or modify it + under the terms of the GNU General Public License as published + by the Free Software Foundation; either version 3, or (at your + option) any later version. + + GCC is distributed in the hope that it will be useful, but WITHOUT + ANY WARRANTY; without even the implied warranty of MERCHANTABILITY + or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public + License for more details. + + Under Section 7 of GPL version 3, you are granted additional + permissions described in the GCC Runtime Library Exception, version + 3.1, as published by the Free Software Foundation. + + You should have received a copy of the GNU General Public License and + a copy of the GCC Runtime Library Exception along with this program; + see the files COPYING3 and COPYING.RUNTIME respectively. If not, see + . */ + +#if TARGET_MLIB_ARCH == 1 + +# if TARGET_MLIB_ABI == 1 +# define MULTILIB_DEFAULTS {"march=rv32gc", "mabi=ilp32" } +# elif TARGET_MLIB_ABI == 2 +# define MULTILIB_DEFAULTS {"march=rv32gc", "mabi=ilp32f" } +# elif TARGET_MLIB_ABI == 3 +# define MULTILIB_DEFAULTS {"march=rv32gc", "mabi=ilp32d" } +# else +# error "unsupported TARGET_MLIB_ABI value for rv32gc" +# endif + +#elif TARGET_MLIB_ARCH == 2 + +# if TARGET_MLIB_ABI == 4 +# define MULTILIB_DEFAULTS {"march=rv64gc", "mabi=lp64" } +# elif TARGET_MLIB_ABI == 5 +# define MULTILIB_DEFAULTS {"march=rv64gc", "mabi=lp64f" } +# elif TARGET_MLIB_ABI == 6 +# define MULTILIB_DEFAULTS {"march=rv64gc", "mabi=lp64d" } +# else +# error "unsupported TARGET_MLIB_ABI value for rv64gc" +# endif + +#else +# error "unsupported TARGET_MLIB_ARCH value" +#endif diff --git a/gcc/doc/install.texi b/gcc/doc/install.texi index ec20fd266..7c5cdc762 100644 --- a/gcc/doc/install.texi +++ b/gcc/doc/install.texi @@ -1072,8 +1072,8 @@ sysv, aix. @itemx --without-multilib-list Specify what multilibs to build. @var{list} is a comma separated list of values, possibly consisting of a single value. Currently only implemented -for arm*-*-*, sh*-*-* and x86-64-*-linux*. The accepted values and meaning -for each target is given below. +for arm*-*-*, riscv*-*-*, sh*-*-* and x86-64-*-linux*. The accepted +values and meaning for each target is given below. @table @code @item arm*-*-* @@ -1128,6 +1128,13 @@ and @code{rmprofile}. @code{-mfloat-abi=hard} @end multitable +@item riscv*-*-* +@var{list} is a single ABI name. The target architecture must be either +@code{rv32gc} or @code{rv64gc}. This will build a single multilib for the +specified architecture and ABI pair. If @code{--with-multilib-list} is not +given, then a default set of multilibs is selected based on the value of +@option{--target}. This is usually a large set of multilibs. + @item sh*-*-* @var{list} is a comma separated list of CPU names. These must be of the form @code{sh*} or @code{m*} (in which case they match the compiler option