Merge pull request #1201 from abrodkin/topic-glibc-multilib

ARC: Support building of multi-lib Glibc toolchain
This commit is contained in:
Alexey Neyman 2019-12-23 15:17:34 -08:00 committed by GitHub
commit be5d0317d2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 46 additions and 0 deletions

View File

@ -0,0 +1,7 @@
CT_CONFIG_VERSION="3"
CT_ARCH_ARC=y
CT_MULTILIB=y
CT_TARGET_CFLAGS="-matomic"
CT_TARGET_VENDOR="multilib"
CT_TARGET_ALIAS="arc-linux"
CT_KERNEL_LINUX=y

View File

@ -0,0 +1,3 @@
reporter_name="Alexey Brodkin"
reporter_url="http://embarc.org"
reporter_comment="ARC multilib GNU Linux toolchain"

View File

@ -29,3 +29,39 @@ CT_DoArchUClibcCflags()
esac esac
done done
} }
# Multilib: Adjust configure arguments for GLIBC
# Usage: CT_DoArchGlibcAdjustConfigure <configure-args-array-name> <cflags>
#
# From GCC's standpoint ARC's multilib items are defined by "mcpu" values
# which we have quite a few and for all of them might be built optimized
# cross-toolchain.
#
# From Glibc's standpoint multilib is multi-ABI and so very limited
# versions are supposed to co-exist.
#
# Here we force Glibc to install libraries in per-multilib folder to create
# a universal cross-toolchain that has libs optimized for multiple CPU types.
CT_DoArchGlibcAdjustConfigure() {
local -a add_args
local array="${1}"
local cflags="${2}"
local opt
local mcpu
# If building for multilib, set proper installation paths
if [ "${CT_MULTILIB}" = "y" ]; then
for opt in ${cflags}; do
case "${opt}" in
-mcpu=*)
mcpu="${opt#*=}"
add_args+=( "libc_cv_rtlddir=/lib/${mcpu}" )
add_args+=( "libc_cv_slibdir=/lib/${mcpu}" )
add_args+=( "--libdir=/usr/lib/${mcpu}" )
;;
esac
done
fi
eval "${array}+=( \"\${add_args[@]}\" )"
}