diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2020-02-11 15:36:13 -0800 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2020-02-11 15:36:31 -0800 |
commit | 22fe7df8c964c23f5760ecf9653af86ede8b5030 (patch) | |
tree | 61d7b7af342621e302adacaf9b1a855afa55845e /bfd | |
parent | 69ed9b74b61359d43a6f5f5a295c3cfb7f3ee61c (diff) | |
download | gdb-22fe7df8c964c23f5760ecf9653af86ede8b5030.zip gdb-22fe7df8c964c23f5760ecf9653af86ede8b5030.tar.gz gdb-22fe7df8c964c23f5760ecf9653af86ede8b5030.tar.bz2 |
Plugin: Treat each object as independent
Since plugin treats each object as independent, we must do a fresh dlopen
of plugin for each object.
PR binutils/25355
* plugin.c (try_claim): Always clean up for LTO wrapper.
(try_load_plugin): Treat each object as independent. Create a
copy for plugin name.
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 7 | ||||
-rw-r--r-- | bfd/plugin.c | 76 |
2 files changed, 45 insertions, 38 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 52360a7..98a027e 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,10 @@ +2020-02-11 H.J. Lu <hongjiu.lu@intel.com> + + PR binutils/25355 + * plugin.c (try_claim): Always clean up for LTO wrapper. + (try_load_plugin): Treat each object as independent. Create a + copy for plugin name. + 2020-02-11 Nick Clifton <nickc@redhat.com> * elf32-msp430.c (msp430_final_link_relocate): Always use longs diff --git a/bfd/plugin.c b/bfd/plugin.c index 5681a6a..d941677 100644 --- a/bfd/plugin.c +++ b/bfd/plugin.c @@ -549,9 +549,8 @@ try_claim (bfd *abfd) struct ld_plugin_input_file file; file.handle = abfd; - if (!bfd_plugin_open_input (abfd, &file)) - return 0; - if (current_plugin->claim_file) + if (bfd_plugin_open_input (abfd, &file) + && current_plugin->claim_file) { current_plugin->claim_file (&file, &claimed); if (claimed) @@ -577,14 +576,18 @@ try_claim (bfd *abfd) } } - if (current_plugin->lto_wrapper) - { - /* Clean up for LTO wrapper. */ - unlink (current_plugin->resolution_file); - free (current_plugin->resolution_option); - } + close (file.fd); } - close (file.fd); + + if (current_plugin->lto_wrapper) + { + /* Clean up for LTO wrapper. NB: Resolution file and option + have been created regardless if an IR object is claimed or + not. */ + unlink (current_plugin->resolution_file); + free (current_plugin->resolution_option); + } + return claimed; } @@ -600,16 +603,15 @@ try_load_plugin (const char *pname, bfd *abfd, int *has_plugin_p) *has_plugin_p = 0; - /* NB: Each object is inddependent. Reuse the previous plugin from - the last LTO wrapper run will lead to wrong LTO data. */ - if (current_plugin - && current_plugin->handle - && current_plugin->lto_wrapper - && strcmp (current_plugin->plugin_name, pname) == 0) + /* NB: Each object is independent. Reuse the previous plugin from + the last run will lead to wrong result. */ + if (current_plugin) { - dlclose (current_plugin->handle); + if (current_plugin->handle) + dlclose (current_plugin->handle); memset (current_plugin, 0, offsetof (struct plugin_list_entry, next)); + current_plugin = NULL; } plugin_handle = dlopen (pname, RTLD_NOW); @@ -622,31 +624,30 @@ try_load_plugin (const char *pname, bfd *abfd, int *has_plugin_p) for (plugin_list_iter = plugin_list; plugin_list_iter; plugin_list_iter = plugin_list_iter->next) + if (strcmp (plugin_list_iter->plugin_name, pname) == 0) + break; + + if (plugin_list_iter == NULL) { - if (plugin_handle == plugin_list_iter->handle) + size_t length_plugin_name = strlen (pname) + 1; + char *plugin_name = bfd_malloc (length_plugin_name); + if (plugin_name == NULL) + return 0; + plugin_list_iter = bfd_malloc (sizeof *plugin_list_iter); + if (plugin_list_iter == NULL) { - dlclose (plugin_handle); - if (!plugin_list_iter->claim_file) - return 0; - - register_claim_file (plugin_list_iter->claim_file); - current_plugin = plugin_list_iter; - goto have_claim_file; + free (plugin_name); + return 0; } - else if (plugin_list_iter->lto_wrapper - && strcmp (plugin_list_iter->plugin_name, pname) == 0) - goto have_lto_wrapper; + /* Make a copy of PNAME since PNAME from load_plugin () will be + freed. */ + memcpy (plugin_name, pname, length_plugin_name); + memset (plugin_list_iter, 0, sizeof (*plugin_list_iter)); + plugin_list_iter->plugin_name = plugin_name; + plugin_list_iter->next = plugin_list; + plugin_list = plugin_list_iter; } - plugin_list_iter = bfd_malloc (sizeof *plugin_list_iter); - if (plugin_list_iter == NULL) - return 0; - memset (plugin_list_iter, 0, sizeof (*plugin_list_iter)); - plugin_list_iter->plugin_name = pname; - plugin_list_iter->next = plugin_list; - plugin_list = plugin_list_iter; - -have_lto_wrapper: plugin_list_iter->handle = plugin_handle; onload = dlsym (plugin_handle, "onload"); @@ -716,7 +717,6 @@ have_lto_wrapper: && setup_lto_wrapper_env (current_plugin)) return 0; -have_claim_file: *has_plugin_p = 1; abfd->plugin_format = bfd_plugin_no; |