]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
ld: Document mixing LTO and non-LTO objects for -r
authorH.J. Lu <hjl.tools@gmail.com>
Fri, 10 Jan 2025 23:23:27 +0000 (07:23 +0800)
committerH.J. Lu <hjl.tools@gmail.com>
Mon, 13 Jan 2025 21:22:04 +0000 (05:22 +0800)
* ld.texi: Document mixing LTO and non-LTO relocatable files for
"ld -r".

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

index da714a2085582b94687fa0e3970f6dabe64421e8..d1787453f57f69b8039540ecf17e89957feb93c2 100644 (file)
@@ -1126,6 +1126,18 @@ relocations.  Different output formats can have further restrictions; for
 example some @code{a.out}-based formats do not support partial linking
 with input files in other formats at all.
 
+On ELF platforms, when the relocatable output contains both contents
+which require link-time optimization (LTO) and contents which don't
+require LTO, a .gnu_object_only section will be created to contain a
+relocatable object file, as if @samp{-r} is applied to all relocatable
+inputs which don't require LTO.  When processing a relocatable input
+with a .gnu_object_only section, the linker will extract the
+.gnu_object_only section as a separate input.
+
+Note that since @samp{-r} groups some sections from different input files
+together, there may be negative impacts on code size and locality in
+final executable or shared library.
+
 This option does the same thing as @samp{-i}.
 
 @kindex -R @var{file}