aboutsummaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorYuriy Kolerov <ykolerov@synopsys.com>2023-05-12 09:33:55 +0400
committerChris Packham <judge.packham@gmail.com>2023-05-19 15:54:16 +1200
commitf283bb6b1a877cc7ef36304aa165c55daab7d409 (patch)
tree0e3d6cb08436264b8a0fe2eb3659c660356c4fd9 /scripts
parent65e5960a39031504b0b1d189e634d998aa5fbb97 (diff)
downloadcrosstool-ng-f283bb6b1a877cc7ef36304aa165c55daab7d409.tar.gz
crosstool-ng-f283bb6b1a877cc7ef36304aa165c55daab7d409.tar.bz2
crosstool-ng-f283bb6b1a877cc7ef36304aa165c55daab7d409.zip
mpfr: Add support of building MPFR for target
It's necessary for building native GDB 13+. It depends on MPFR but it hasn't presented in scripts yet for building for target. Signed-off-by: Yuriy Kolerov <ykolerov@synopsys.com>
Diffstat (limited to 'scripts')
-rw-r--r--scripts/build/companion_libs/110-mpfr.sh56
1 files changed, 53 insertions, 3 deletions
diff --git a/scripts/build/companion_libs/110-mpfr.sh b/scripts/build/companion_libs/110-mpfr.sh
index 3a1916c5..9fc4e24d 100644
--- a/scripts/build/companion_libs/110-mpfr.sh
+++ b/scripts/build/companion_libs/110-mpfr.sh
@@ -9,7 +9,7 @@ do_mpfr_for_host() { :; }
do_mpfr_for_target() { :; }
# Overide function depending on configuration
-if [ "${CT_MPFR}" = "y" ]; then
+if [ "${CT_MPFR_TARGET}" = "y" -o "${CT_MPFR}" = "y" ]; then
# Download MPFR
do_mpfr_get() {
@@ -82,17 +82,45 @@ do_mpfr_for_host() {
CT_EndStep
}
+if [ "${CT_MPFR_TARGET}" = "y" ]; then
+do_mpfr_for_target() {
+ local -a mpfr_opts
+
+ CT_DoStep INFO "Installing MPFR for target"
+ CT_mkdir_pushd "${CT_BUILD_DIR}/build-mpfr-target-${CT_HOST}"
+
+ mpfr_opts+=( "host=${CT_TARGET}" )
+ case "${CT_TARGET}" in
+ *-*-mingw*)
+ prefix="/mingw"
+ ;;
+ *)
+ prefix="/usr"
+ ;;
+ esac
+ mpfr_opts+=( "cflags=${CT_ALL_TARGET_CFLAGS}" )
+ mpfr_opts+=( "prefix=${prefix}" )
+ mpfr_opts+=( "destdir=${CT_SYSROOT_DIR}" )
+ do_mpfr_backend "${mpfr_opts[@]}"
+
+ CT_Popd
+ CT_EndStep
+}
+fi
+
# Build MPFR
# Parameter : description : type : default
# host : machine to run on : tuple : (none)
# prefix : prefix to install into : dir : (none)
# cflags : cflags to use : string : (empty)
# ldflags : ldflags to use : string : (empty)
+# destdir : install destination : dir : (none)
do_mpfr_backend() {
local host
local prefix
local cflags
local ldflags
+ local destdir
local arg
local -a extra_config
@@ -123,13 +151,35 @@ do_mpfr_backend() {
--host=${host} \
--prefix="${prefix}" \
"${extra_config[@]}" \
- --with-gmp="${prefix}" \
+ --with-gmp="${destdir}${prefix}" \
--disable-shared \
--enable-static
+ # If "${destdir}${prefix}" != "${prefix}" then it means that native MPFR
+ # is being built. In this case libgmp.la must be moved away while
+ # building MPFR. Otherwise libmpfr.la will contain this:
+ #
+ # dependency_libs=' -L<path-to-build-dir>/lib /usr/lib/libgmp.la'
+ #
+ # Build system then tries to link MPFR with host's libgmp.a. It happens
+ # because libgmp.a and libmpfr.a are built with --prefix=/usr while
+ # cross-compiling for target and MPFR depends on GMP. In this case
+ # libtool thinks that GMP resides in /usr/lib and uses wrong path.
+ # The only way to avoid such behavior is to replace libgmp.la
+ # temporarily to force libtool using -lgmp option instead wrong one.
+ if [ "${destdir}${prefix}" != "${prefix}" ]; then
+ if [ -f ${destdir}${prefix}/lib/libgmp.la ]; then
+ mv ${destdir}${prefix}/lib/libgmp.la ${destdir}${prefix}/lib/libgmp.la.bk
+ fi
+ fi
+
CT_DoLog EXTRA "Building MPFR"
CT_DoExecLog ALL make ${CT_JOBSFLAGS}
+ if [ -f ${destdir}${prefix}/lib/libgmp.la.bk ]; then
+ mv ${destdir}${prefix}/lib/libgmp.la.bk ${destdir}${prefix}/lib/libgmp.la
+ fi
+
if [ "${CT_COMPLIBS_CHECK}" = "y" ]; then
if [ "${host}" = "${CT_BUILD}" ]; then
CT_DoLog EXTRA "Checking MPFR"
@@ -141,7 +191,7 @@ do_mpfr_backend() {
fi
CT_DoLog EXTRA "Installing MPFR"
- CT_DoExecLog ALL make install
+ CT_DoExecLog ALL make install DESTDIR="${destdir}"
}
fi # CT_MPFR