From: Alan Modra Date: Thu, 15 Feb 2024 06:25:59 +0000 (+1030) Subject: PR28448, Memory leak in function add_symbols(plugin.c) X-Git-Tag: gdb-15-branchpoint~967 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=19bfbfa6659c7733d3148dcce5125a0eb3fd9670;p=thirdparty%2Fbinutils-gdb.git PR28448, Memory leak in function add_symbols(plugin.c) PR 28448 * plugin.c (add_symbols): bfd_alloc memory for symptrs. Check bfd_make_empty_symbol return. --- diff --git a/ld/plugin.c b/ld/plugin.c index e982869072b..f81ab02b3a6 100644 --- a/ld/plugin.c +++ b/ld/plugin.c @@ -506,7 +506,9 @@ add_symbols (void *handle, int nsyms, const struct ld_plugin_symbol *syms) int n; ASSERT (called_plugin); - symptrs = xmalloc (nsyms * sizeof *symptrs); + symptrs = bfd_alloc (abfd, nsyms * sizeof *symptrs); + if (symptrs == NULL) + return LDPS_ERR; for (n = 0; n < nsyms; n++) { enum ld_plugin_status rv; @@ -514,6 +516,8 @@ add_symbols (void *handle, int nsyms, const struct ld_plugin_symbol *syms) bfdsym = bfd_make_empty_symbol (abfd); symptrs[n] = bfdsym; + if (bfdsym == NULL) + return LDPS_ERR; rv = asymbol_from_plugin_symbol (abfd, bfdsym, syms + n); if (rv != LDPS_OK) return rv;