diff options
Diffstat (limited to 'meta/recipes-devtools/binutils/binutils/0019-Fix-gold-to-use-mallinfo2-if-available-instead-of-de.patch')
-rw-r--r-- | meta/recipes-devtools/binutils/binutils/0019-Fix-gold-to-use-mallinfo2-if-available-instead-of-de.patch | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/meta/recipes-devtools/binutils/binutils/0019-Fix-gold-to-use-mallinfo2-if-available-instead-of-de.patch b/meta/recipes-devtools/binutils/binutils/0019-Fix-gold-to-use-mallinfo2-if-available-instead-of-de.patch new file mode 100644 index 0000000000..d6e4e25b3d --- /dev/null +++ b/meta/recipes-devtools/binutils/binutils/0019-Fix-gold-to-use-mallinfo2-if-available-instead-of-de.patch @@ -0,0 +1,78 @@ +From 5a47430c1dc7b998b9db3ca9e4c93394c7a9972e Mon Sep 17 00:00:00 2001 +From: Duncan Simpson <dr.duncan.p.simpson@gmail.com> +Date: Fri, 19 Mar 2021 14:22:08 -0700 +Subject: [PATCH] Fix gold to use mallinfo2 if available instead of deprecated + mallinfo. + +gold/ + PR gold/26585 + * configure.ac: Add check for mallinfo2. + * configure: Regenerate. + * main.cc (main): Use mallinfo2 if available. + +Upstream-Status: Backport [4ee60495054 Fix gold to use mallinfo2 if available instead of deprecated mallinfo.] + +Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com> +--- + gold/configure | 2 +- + gold/configure.ac | 2 +- + gold/main.cc | 9 +++++++-- + 3 files changed, 9 insertions(+), 4 deletions(-) + +diff --git a/gold/configure b/gold/configure +index e264a65ac3c..b9f062b68eb 100755 +--- a/gold/configure ++++ b/gold/configure +@@ -9967,7 +9967,7 @@ case "$ac_cv_search_dlopen" in + esac + + +-for ac_func in mallinfo posix_fallocate fallocate readv sysconf times mkdtemp ++for ac_func in mallinfo mallinfo2 posix_fallocate fallocate readv sysconf times mkdtemp + do : + as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh` + ac_fn_cxx_check_func "$LINENO" "$ac_func" "$as_ac_var" +diff --git a/gold/configure.ac b/gold/configure.ac +index eed45664093..1716a779416 100644 +--- a/gold/configure.ac ++++ b/gold/configure.ac +@@ -636,7 +636,7 @@ case "$ac_cv_search_dlopen" in + esac + AC_SUBST(DLOPEN_LIBS) + +-AC_CHECK_FUNCS(mallinfo posix_fallocate fallocate readv sysconf times mkdtemp) ++AC_CHECK_FUNCS(mallinfo mallinfo2 posix_fallocate fallocate readv sysconf times mkdtemp) + AC_CHECK_DECLS([basename, ffs, asprintf, vasprintf, snprintf, vsnprintf, strverscmp, strndup, memmem]) + + # Use of ::std::tr1::unordered_map::rehash causes undefined symbols +diff --git a/gold/main.cc b/gold/main.cc +index ea77ca3ebbe..89bc40b22af 100644 +--- a/gold/main.cc ++++ b/gold/main.cc +@@ -25,7 +25,7 @@ + #include <cstdio> + #include <cstring> + +-#ifdef HAVE_MALLINFO ++#if defined(HAVE_MALLINFO) || defined(HAVE_MALLINFO2) + #include <malloc.h> + #endif + +@@ -290,11 +290,16 @@ main(int argc, char** argv) + elapsed.sys / 1000, (elapsed.sys % 1000) * 1000, + elapsed.wall / 1000, (elapsed.wall % 1000) * 1000); + +-#ifdef HAVE_MALLINFO ++#if defined(HAVE_MALLINFO2) ++ struct mallinfo m = mallinfo2(); ++ fprintf(stderr, _("%s: total space allocated by malloc: %lld bytes\n"), ++ program_name, static_cast<long long>(m.arena)); ++#elif defined(HAVE_MALLINFO) + struct mallinfo m = mallinfo(); + fprintf(stderr, _("%s: total space allocated by malloc: %lld bytes\n"), + program_name, static_cast<long long>(m.arena)); + #endif ++ + File_read::print_stats(); + Archive::print_stats(); + Lib_group::print_stats(); |