Fix gold to use mallinfo2 if available instead of deprecated mallinfo.
authorDuncan Simpson <dr.duncan.p.simpson@gmail.com>
Fri, 19 Mar 2021 21:22:08 +0000 (14:22 -0700)
committerCary Coutant <ccoutant@gmail.com>
Fri, 19 Mar 2021 21:22:08 +0000 (14:22 -0700)
gold/
PR gold/26585
* configure.ac: Add check for mallinfo2.
* configure: Regenerate.
* main.cc (main): Use mallinfo2 if available.

gold/ChangeLog
gold/configure
gold/configure.ac
gold/main.cc

index 09e1fc505acc05a036837062a89c37e2dcf54f5c..bd23e151d3c30dd7c519d5979b0d7c9fbfadba06 100644 (file)
@@ -1,3 +1,10 @@
+2021-03-19  Duncan Simpson <dr.duncan.p.simpson@gmail.com>
+
+       PR gold/26585
+       * configure.ac: Add check for mallinfo2.
+       * configure: Regenerate.
+       * main.cc (main): Use mallinfo2 if available.
+
 2021-03-19  Cary Coutant  <ccoutant@gmail.com>
 
        PR gold/27246
index e264a65ac3c680ed1c64221eb115f852f5157eda..b9f062b68eb480971b709eee85be9fd22eb25ac6 100755 (executable)
@@ -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"
index eed45664093cc097eb69cb579b88c50b98d0ccf8..1716a779416a579d7514b280842fee88fde343cc 100644 (file)
@@ -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
index ea77ca3ebbe8a5c6ae55b2ee6f5a17998b186272..89bc40b22af50de39fd0afeb5e694bdf6771ad50 100644 (file)
@@ -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();