2007-11-24 23:15:56

by Denys Vlasenko

[permalink] [raw]
Subject: [PATCH 0/3] build system: section garbage collection

Hi Sam,

On Sunday 18 November 2007 15:00, Sam Ravnborg wrote:
> On Tue, Sep 11, 2007 at 09:05:33PM +0100, Denys Vlasenko wrote:
> > Build system: section garbage collection for vmlinux
> >
> > Newer gcc and binutils can do dead code and data removal
> > at link time. It is achieved using combination of
> > -ffunction-sections -fdata-sections options for gcc and
> > --gc-sections for ld.
>
> ...
> Hi Denys.
>
> We are now well pass the merge window and I like this patchset to show up
> in -mm. But I'm lacking time myself and wondered if you can send an updated
> version based on the latest -git tree from Linus?

Got around to do this.

1.fixname:
Rename all special sections with names like .text.xxxx, .data.xxxx and
.rodata.xxxx to .xxxx.text/data/rodata. This makes it possible to
not mix up these sections with gcc-generated ones
when gcc -ffunction-sections -fdata-sections is used.
.bss.xxxx cannot be treated this way, because for section names
linke .xxxx.bss gcc won't create section with correct attribute.
Thus .bss.xxxxx sections are renamed .bss.k.xxxxx.

2.modpost
Update scripts/mod/* machinery to correctly handle the case
when we have more than 64k sections.

3.gc
The meat of the patchset is here.
Introduce config option DISCARD_UNUSED_SECTIONS.
If it is selected:
Pass -ffunction-sections -fdata-sections to gcc and
--gc-sections --print-gc-sections to ld.
Use arch/$(SRCARCH)/kernel/modules.lds.S linker script for linking *.ko
files.
Generate linker map files for vmlinux and modules.
Add *(.text.*), *(.data.*) wildcards to linker scripts to accomodate
new kinds of sections generated by gcc.
Add KEEP(<sections>) directives to sections which must not be discarded.
Fix arch/frv/Makefile to use DISCARD_UNUSED_SECTIONS instead
of what seems to be a vestigial custom solution.

Patches are against yesterday's Linus git tree and should be applied in order.
They should not have any effect at all if DISCARD_UNUSED_SECTIONS is off.
DISCARD_UNUSED_SECTIONS is marked DANGEROUS for now.
It is likely to not work on arches other than x86 (modules.lds needs to be
added for each arch).

Compile and run tested on 32-bit x86 (running this kernel now).

Signed-off-by: Denys Vlasenko <[email protected]>
--
vda


2007-11-24 23:17:22

by Denys Vlasenko

[permalink] [raw]
Subject: [PATCH 1/3] build system: section garbage collection - rename sections

On Saturday 24 November 2007 15:14, Denys Vlasenko wrote:
> 1.fixname:
> Rename all special sections with names like .text.xxxx, .data.xxxx and
> .rodata.xxxx to .xxxx.text/data/rodata. This makes it possible to
> not mix up these sections with gcc-generated ones
> when gcc -ffunction-sections -fdata-sections is used.
> .bss.xxxx cannot be treated this way, because for section names
> linke .xxxx.bss gcc won't create section with correct attribute.
> Thus .bss.xxxxx sections are renamed .bss.k.xxxxx.

Signed-off-by: Denys Vlasenko <[email protected]>
--
vda


Attachments:
(No filename) (600.00 B)
linux-2.6-linus_git.1.fixname.patch (103.13 kB)
Download all attachments

2007-11-24 23:18:00

by Denys Vlasenko

[permalink] [raw]
Subject: [PATCH 2/3] build system: section garbage collection - modpost fix

On Saturday 24 November 2007 15:14, Denys Vlasenko wrote:
> 2.modpost
> Update scripts/mod/* machinery to correctly handle the case
> when we have more than 64k sections.

Signed-off-by: Denys Vlasenko <[email protected]>
--
vda


Attachments:
(No filename) (245.00 B)
linux-2.6-linus_git.2.modpost_fix.patch (9.60 kB)
Download all attachments

2007-11-24 23:18:52

by Denys Vlasenko

[permalink] [raw]
Subject: [PATCH 3/3] build system: section garbage collection - main part

On Saturday 24 November 2007 15:14, Denys Vlasenko wrote:
> 3.gc
> The meat of the patchset is here.
> Introduce config option DISCARD_UNUSED_SECTIONS.
> If it is selected:
> Pass -ffunction-sections -fdata-sections to gcc and
> --gc-sections --print-gc-sections to ld.
> Use arch/$(SRCARCH)/kernel/modules.lds.S linker script for linking *.ko
> files.
> Generate linker map files for vmlinux and modules.
> Add *(.text.*), *(.data.*) wildcards to linker scripts to accomodate
> new kinds of sections generated by gcc.
> Add KEEP(<sections>) directives to sections which must not be
> discarded. Fix arch/frv/Makefile to use DISCARD_UNUSED_SECTIONS instead
> of what seems to be a vestigial custom solution.

Signed-off-by: Denys Vlasenko <[email protected]>
--
vda


Attachments:
(No filename) (826.00 B)
linux-2.6-linus_git.3.gc.patch (46.38 kB)
Download all attachments

2008-06-24 07:30:13

by Matthieu CASTET

[permalink] [raw]
Subject: Re: [PATCH 1/3] build system: section garbage collection - rename sections

Hi,

Denys Vlasenko <vda.linux <at> googlemail.com> writes:

>
> On Saturday 24 November 2007 15:14, Denys Vlasenko wrote:
> > 1.fixname:
> > Rename all special sections with names like .text.xxxx, .data.xxxx and
> > .rodata.xxxx to .xxxx.text/data/rodata. This makes it possible to
> > not mix up these sections with gcc-generated ones
> > when gcc -ffunction-sections -fdata-sections is used.
> > .bss.xxxx cannot be treated this way, because for section names
> > linke .xxxx.bss gcc won't create section with correct attribute.
> > Thus .bss.xxxxx sections are renamed .bss.k.xxxxx.
>
> Signed-off-by: Denys Vlasenko <vda.linux <at> googlemail.com>
Why not rename all the section to .type.k.xxxxx ?
This will be more consistent between bss and other section. Also I find it
cleaner to have the section type first.

Matthieu