]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
lto: Set plugin_format to bfd_plugin_no only if known_used is set
authorH.J. Lu <hjl.tools@gmail.com>
Tue, 28 Oct 2025 12:21:19 +0000 (20:21 +0800)
committerH.J. Lu <hjl.tools@gmail.com>
Thu, 30 Oct 2025 23:52:23 +0000 (07:52 +0800)
commit b21318bd2c29fcca8f99c1de7facdaa5cb2e66e2
Author: Joseph Myers <joseph@codesourcery.com>
Date:   Thu May 11 14:31:09 2023 +0000

    Add LDPT_REGISTER_CLAIM_FILE_HOOK_V2 linker plugin hook [GCC PR109128]

added the LDPT_REGISTER_CLAIM_FILE_HOOK_V2 linker plugin hook for offload
support.  Since the V2 linker plugin hook doesn't claim the offload IR if
known_used is unset, set input plugin_format to bfd_plugin_no only if
known_used is set or the V2 linker plugin hook is unused.

PR ld/33584
* plugin.c (plugin_object_p): Set plugin_format to bfd_plugin_no
only if known_used is set or the V2 linker plugin hook is unused.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
ld/plugin.c

index 08d827c1ec7849f581dd21fcb68edec221cd8328..7e4eaf9cee4d36865504837c6300a5021ed52706 100644 (file)
@@ -1326,8 +1326,13 @@ plugin_object_p (bfd *ibfd, bool known_used)
 #endif
 
       /* If plugin didn't claim the file, we don't need the dummy bfd.
-        Can't avoid speculatively creating it, alas.  */
-      ibfd->plugin_format = bfd_plugin_no;
+        Can't avoid speculatively creating it, alas.  NB: Set input
+        plugin_format to bfd_plugin_no only if known_used is set or
+        the LDPT_REGISTER_CLAIM_FILE_HOOK_V2 linker plugin hook is
+        unused since the V2 linker plugin hook doesn't claim the
+        offload IR if known_used is unset.  */
+      if (known_used || !claim_file_handler_v2)
+       ibfd->plugin_format = bfd_plugin_no;
       bfd_close_all_done (abfd);
       return NULL;
     }