2020-02-19 14:03:33 +01:00
|
|
|
From d9d92bacb7adb4bab0c26eb7458203345a0faf13 Mon Sep 17 00:00:00 2001
|
2020-02-18 14:21:10 +01:00
|
|
|
From: "H.J. Lu" <hjl.tools@gmail.com>
|
|
|
|
Date: Tue, 18 Feb 2020 04:22:34 -0800
|
|
|
|
Subject: [PATCH] plugin: Call dlclose before return in try_load_plugin
|
|
|
|
|
|
|
|
Since plugin can be used only once in try_load_plugin, call dlclose
|
|
|
|
before return.
|
|
|
|
|
|
|
|
PR binutils/25355
|
|
|
|
* plugin.c (plugin_list_entry): Remove handle.
|
|
|
|
(try_load_plugin): Call dlclose before return.
|
|
|
|
---
|
2020-02-19 14:03:33 +01:00
|
|
|
bfd/plugin.c | 39 ++++++++++++++++++---------------------
|
|
|
|
1 file changed, 18 insertions(+), 21 deletions(-)
|
2020-02-18 14:21:10 +01:00
|
|
|
|
|
|
|
diff --git a/bfd/plugin.c b/bfd/plugin.c
|
2020-02-19 14:03:33 +01:00
|
|
|
index 47c3439042..93d562b9fe 100644
|
2020-02-18 14:21:10 +01:00
|
|
|
--- a/bfd/plugin.c
|
|
|
|
+++ b/bfd/plugin.c
|
|
|
|
@@ -126,7 +126,6 @@ message (int level ATTRIBUTE_UNUSED,
|
|
|
|
struct plugin_list_entry
|
|
|
|
{
|
|
|
|
/* These must be initialized for each IR object with LTO wrapper. */
|
|
|
|
- void *handle;
|
|
|
|
ld_plugin_claim_file_handler claim_file;
|
|
|
|
ld_plugin_all_symbols_read_handler all_symbols_read;
|
|
|
|
ld_plugin_all_symbols_read_handler cleanup_handler;
|
2020-02-19 14:03:33 +01:00
|
|
|
@@ -596,22 +595,18 @@ try_load_plugin (const char *pname,
|
2020-02-18 14:21:10 +01:00
|
|
|
struct plugin_list_entry *plugin_list_iter,
|
|
|
|
bfd *abfd, bfd_boolean build_list_p)
|
|
|
|
{
|
|
|
|
- void *plugin_handle = NULL;
|
|
|
|
+ void *plugin_handle;
|
|
|
|
struct ld_plugin_tv tv[12];
|
|
|
|
int i;
|
|
|
|
ld_plugin_onload onload;
|
|
|
|
enum ld_plugin_status status;
|
2020-02-19 14:03:33 +01:00
|
|
|
+ int result = 0;
|
|
|
|
|
|
|
|
/* NB: Each object is independent. Reuse the previous plugin from
|
|
|
|
the last run will lead to wrong result. */
|
|
|
|
if (current_plugin)
|
2020-02-18 14:21:10 +01:00
|
|
|
- {
|
|
|
|
- if (current_plugin->handle)
|
|
|
|
- dlclose (current_plugin->handle);
|
|
|
|
- memset (current_plugin, 0,
|
|
|
|
- offsetof (struct plugin_list_entry, next));
|
|
|
|
- current_plugin = NULL;
|
|
|
|
- }
|
2020-02-19 14:03:33 +01:00
|
|
|
+ memset (current_plugin, 0,
|
|
|
|
+ offsetof (struct plugin_list_entry, next));
|
2020-02-18 14:21:10 +01:00
|
|
|
|
|
|
|
if (plugin_list_iter)
|
|
|
|
pname = plugin_list_iter->plugin_name;
|
2020-02-19 14:03:33 +01:00
|
|
|
@@ -628,12 +623,12 @@ try_load_plugin (const char *pname,
|
2020-02-18 14:21:10 +01:00
|
|
|
size_t length_plugin_name = strlen (pname) + 1;
|
|
|
|
char *plugin_name = bfd_malloc (length_plugin_name);
|
|
|
|
if (plugin_name == NULL)
|
|
|
|
- return 0;
|
|
|
|
+ goto short_circuit;
|
|
|
|
plugin_list_iter = bfd_malloc (sizeof *plugin_list_iter);
|
|
|
|
if (plugin_list_iter == NULL)
|
|
|
|
{
|
|
|
|
free (plugin_name);
|
|
|
|
- return 0;
|
|
|
|
+ goto short_circuit;
|
|
|
|
}
|
|
|
|
/* Make a copy of PNAME since PNAME from load_plugin () will be
|
|
|
|
freed. */
|
2020-02-19 14:03:33 +01:00
|
|
|
@@ -644,13 +639,13 @@ try_load_plugin (const char *pname,
|
2020-02-18 14:21:10 +01:00
|
|
|
plugin_list = plugin_list_iter;
|
|
|
|
}
|
|
|
|
|
|
|
|
- plugin_list_iter->handle = plugin_handle;
|
|
|
|
+ current_plugin = plugin_list_iter;
|
|
|
|
if (build_list_p)
|
|
|
|
- return 0;
|
|
|
|
+ goto short_circuit;
|
|
|
|
|
|
|
|
onload = dlsym (plugin_handle, "onload");
|
|
|
|
if (!onload)
|
|
|
|
- return 0;
|
|
|
|
+ goto short_circuit;
|
|
|
|
|
|
|
|
i = 0;
|
|
|
|
tv[i].tv_tag = LDPT_MESSAGE;
|
2020-02-19 14:03:33 +01:00
|
|
|
@@ -703,28 +698,30 @@ try_load_plugin (const char *pname,
|
2020-02-18 14:21:10 +01:00
|
|
|
tv[i].tv_tag = LDPT_NULL;
|
|
|
|
tv[i].tv_u.tv_val = 0;
|
|
|
|
|
|
|
|
- current_plugin = plugin_list_iter;
|
|
|
|
-
|
|
|
|
/* LTO plugin will call handler hooks to set up plugin handlers. */
|
|
|
|
status = (*onload)(tv);
|
|
|
|
|
|
|
|
if (status != LDPS_OK)
|
|
|
|
- return 0;
|
|
|
|
+ goto short_circuit;
|
|
|
|
|
|
|
|
if (current_plugin->lto_wrapper
|
|
|
|
&& setup_lto_wrapper_env (current_plugin))
|
|
|
|
- return 0;
|
|
|
|
+ goto short_circuit;
|
|
|
|
|
|
|
|
abfd->plugin_format = bfd_plugin_no;
|
|
|
|
|
|
|
|
if (!current_plugin->claim_file)
|
|
|
|
- return 0;
|
|
|
|
+ goto short_circuit;
|
|
|
|
|
|
|
|
if (!try_claim (abfd))
|
|
|
|
- return 0;
|
|
|
|
+ goto short_circuit;
|
|
|
|
|
|
|
|
abfd->plugin_format = bfd_plugin_yes;
|
|
|
|
- return 1;
|
|
|
|
+ result = 1;
|
|
|
|
+
|
|
|
|
+short_circuit:
|
|
|
|
+ dlclose (plugin_handle);
|
|
|
|
+ return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* There may be plugin libraries in lib/bfd-plugins. */
|
|
|
|
--
|
|
|
|
2.24.1
|
|
|
|
|