mirror of
https://github.com/crosstool-ng/crosstool-ng.git
synced 2024-12-20 05:17:54 +00:00
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>
This commit is contained in:
parent
65e5960a39
commit
f283bb6b1a
@ -61,6 +61,10 @@ config MPFR_NEEDED
|
|||||||
select GMP_NEEDED
|
select GMP_NEEDED
|
||||||
select COMP_LIBS_MPFR
|
select COMP_LIBS_MPFR
|
||||||
|
|
||||||
|
config MPFR_TARGET
|
||||||
|
bool
|
||||||
|
select COMP_LIBS_MPFR
|
||||||
|
|
||||||
config ISL_NEEDED
|
config ISL_NEEDED
|
||||||
bool
|
bool
|
||||||
select GMP_NEEDED
|
select GMP_NEEDED
|
||||||
|
@ -9,7 +9,7 @@ do_mpfr_for_host() { :; }
|
|||||||
do_mpfr_for_target() { :; }
|
do_mpfr_for_target() { :; }
|
||||||
|
|
||||||
# Overide function depending on configuration
|
# Overide function depending on configuration
|
||||||
if [ "${CT_MPFR}" = "y" ]; then
|
if [ "${CT_MPFR_TARGET}" = "y" -o "${CT_MPFR}" = "y" ]; then
|
||||||
|
|
||||||
# Download MPFR
|
# Download MPFR
|
||||||
do_mpfr_get() {
|
do_mpfr_get() {
|
||||||
@ -82,17 +82,45 @@ do_mpfr_for_host() {
|
|||||||
CT_EndStep
|
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
|
# Build MPFR
|
||||||
# Parameter : description : type : default
|
# Parameter : description : type : default
|
||||||
# host : machine to run on : tuple : (none)
|
# host : machine to run on : tuple : (none)
|
||||||
# prefix : prefix to install into : dir : (none)
|
# prefix : prefix to install into : dir : (none)
|
||||||
# cflags : cflags to use : string : (empty)
|
# cflags : cflags to use : string : (empty)
|
||||||
# ldflags : ldflags to use : string : (empty)
|
# ldflags : ldflags to use : string : (empty)
|
||||||
|
# destdir : install destination : dir : (none)
|
||||||
do_mpfr_backend() {
|
do_mpfr_backend() {
|
||||||
local host
|
local host
|
||||||
local prefix
|
local prefix
|
||||||
local cflags
|
local cflags
|
||||||
local ldflags
|
local ldflags
|
||||||
|
local destdir
|
||||||
local arg
|
local arg
|
||||||
local -a extra_config
|
local -a extra_config
|
||||||
|
|
||||||
@ -123,13 +151,35 @@ do_mpfr_backend() {
|
|||||||
--host=${host} \
|
--host=${host} \
|
||||||
--prefix="${prefix}" \
|
--prefix="${prefix}" \
|
||||||
"${extra_config[@]}" \
|
"${extra_config[@]}" \
|
||||||
--with-gmp="${prefix}" \
|
--with-gmp="${destdir}${prefix}" \
|
||||||
--disable-shared \
|
--disable-shared \
|
||||||
--enable-static
|
--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_DoLog EXTRA "Building MPFR"
|
||||||
CT_DoExecLog ALL make ${CT_JOBSFLAGS}
|
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 [ "${CT_COMPLIBS_CHECK}" = "y" ]; then
|
||||||
if [ "${host}" = "${CT_BUILD}" ]; then
|
if [ "${host}" = "${CT_BUILD}" ]; then
|
||||||
CT_DoLog EXTRA "Checking MPFR"
|
CT_DoLog EXTRA "Checking MPFR"
|
||||||
@ -141,7 +191,7 @@ do_mpfr_backend() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
CT_DoLog EXTRA "Installing MPFR"
|
CT_DoLog EXTRA "Installing MPFR"
|
||||||
CT_DoExecLog ALL make install
|
CT_DoExecLog ALL make install DESTDIR="${destdir}"
|
||||||
}
|
}
|
||||||
|
|
||||||
fi # CT_MPFR
|
fi # CT_MPFR
|
||||||
|
Loading…
Reference in New Issue
Block a user