x86: fold sections in final binaries
authorJan Beulich <jbeulich@suse.com>
Wed, 2 Mar 2022 08:29:55 +0000 (09:29 +0100)
committerJan Beulich <jbeulich@suse.com>
Wed, 2 Mar 2022 08:29:55 +0000 (09:29 +0100)
commit4b7fd8153ddfe95d6d427ff241abb6fdf37e027b
treec96ced419c06a31b73e8f03432aa6fa10d919bd3
parent97b80c7881b36ddb13e535d4e9af0eef2e7f24ec
x86: fold sections in final binaries

Especially when linking a PE binary (xen.efi), standalone output
sections are expensive: Often the linker will align the subsequent one
on the section alignment boundary (2Mb) when the linker script doesn't
otherwise place it. (I haven't been able to derive from observed
behavior under what conditions it would not do so.)

With gcov enabled (and with gcc11) I'm observing enough sections that,
as of quite recently, the resulting image doesn't fit in 16Mb anymore,
failing the final ASSERT() in the linker script. (That assertion is
slated to go away, but that's a separate change.)

Any destructor related sections can be discarded, as we never "exit"
the hypervisor. This includes .text.exit, which is referenced from
.dtors.*. Constructor related sections need to all be taken care of, not
just those with historically used names: .ctors.* and .text.startup is
what gcc11 populates. While there re-arrange ordering / sorting to match
that used by the linker provided scripts.

Finally, for xen.efi only, also discard .note.gnu.*. These are
meaningless in a PE binary. Quite likely, while not meaningless there,
the section is also of no use in ELF, but keep it there for now.

Signed-off-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Roger Pau Monné <roger.pau@citrix.com>
xen/arch/x86/xen.lds.S