Date: Sun, 15 Sep 2013 17:11:41 -0700 From: Matthew Fleming <mdf@FreeBSD.org> To: Ed Schouten <ed@80386.nl> Cc: FreeBSD Current <freebsd-current@freebsd.org> Subject: Re: -ffunction-sections, -fdata-sections and -Wl,--gc-sections Message-ID: <CAMBSHm_Qk13P=j1VOzuibYaeHFVF%2BCuXbTYL=q8ToDP6wL5X5w@mail.gmail.com> In-Reply-To: <CAJOYFBBGY0GosPwG1B=1MKyapChEtX-O97r2zhXpGS8o7WO3gA@mail.gmail.com> References: <CAJOYFBBGY0GosPwG1B=1MKyapChEtX-O97r2zhXpGS8o7WO3gA@mail.gmail.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Sun, Sep 15, 2013 at 2:24 PM, Ed Schouten <ed@80386.nl> wrote: > Hi all, > > Today I did a tiny experiment and I am not entirely sure what to do. > Throw away the patch or eventually push it into the tree. > > GCC and Clang support the -ffunction-sections and -fdata-sections > flags. Essentially, these flags force the compiler to put every > function and variable in its own section. Though this will blow up the > size of the .o files a lot, it has a nice advantage. In combination > with ld's --gc-sections flag, it can garbage collect functions and > variables during the linking phase more accurately, thereby reducing > the size of the resulting binary. This will of course not work for > binaries where you want to use dlsym(), so this would only be safely > usable in cases where you want to do static linking. > > I've written a tiny patch for share/mk, crunchgen and /rescue, to set > these flags, only for .o files that are used for static linking (e.g. > for .a files) and when linking statically linked executables. > > http://80386.nl/pub/gc-sections.txt > > The results are interesting. On amd64: > > - devd suddenly becomes 500 KB in size, instead of a megabyte, > - init's size drops from 900 KB to 600 KB, > - clang becomes a megabyte smaller. > > There is a downside, though. The total size of the system becomes 8 MB > larger, because the .a files in /usr/lib are a bit bigger than before. > Still, I think that this can be justified: > > - Systems short on disk-space are typically not used for software > development. As /usr/include and /usr/lib/*.a together already account > for ~30% of the disk space used, these files will likely be removed on > a disk-space constrained system anyway. > I can confirm that at least one vendor who is constrained on the size of the root partition does not install /usr/include or any *.a files. On shipping hardware. We do use the hardware for developer builds where we do need include files (though not .a files as we only use shared libraries). > - init and devd are so fundamental that they will likely be installed > on basically any embedded FreeBSD system. Reducing the size of these > binaries makes sense. > - It could also reduce the size of statically linked binaries outside > of the base system, depending on base libraries. > > What I also like about this, is that at least for the base system, it > will become less important to spread out functions in libraries over > separate source files, in an attempt to reduce the size of the > resulting binary. We may now leave functions that are related to each > other in the same source file, thus improving readability. > Would it be possible to enable this only for devd, init, and clang binaries? Or is it a matter of enabling it for library builds that are linked statically with the mentioned binaries? Could init/devd be made smaller by finding out which functions they do/don't use and separating those into separate .c files? Thanks, matthew
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CAMBSHm_Qk13P=j1VOzuibYaeHFVF%2BCuXbTYL=q8ToDP6wL5X5w>