2018-05-14 22:09:31 +03:00
|
|
|
# Compute ARC-specific values
|
|
|
|
|
2018-12-10 01:10:01 -08:00
|
|
|
CT_DoArchTupleValues()
|
|
|
|
{
|
2018-05-14 22:09:31 +03:00
|
|
|
# The architecture part of the tuple:
|
|
|
|
CT_TARGET_ARCH="${CT_ARCH}${CT_ARCH_SUFFIX:-${target_endian_eb}}"
|
|
|
|
}
|
|
|
|
|
2018-12-10 01:10:01 -08:00
|
|
|
CT_DoArchUClibcConfig()
|
|
|
|
{
|
2018-05-14 22:09:31 +03:00
|
|
|
local cfg="${1}"
|
|
|
|
|
|
|
|
CT_DoArchUClibcSelectArch "${cfg}" "arc"
|
|
|
|
}
|
|
|
|
|
2019-04-24 14:49:45 +03:00
|
|
|
# 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[@]}\" )"
|
|
|
|
}
|