about summary refs log tree commit diff
path: root/configure
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2015-10-26 11:52:44 +0000
committerLaurent Bercot <ska-skaware@skarnet.org>2015-10-26 11:52:44 +0000
commit6a9ae5d6fdc412d538f5fdd0c47c2b332336df35 (patch)
tree4fa1fe0390c59065fd9ba09550f845bd7de46f77 /configure
parentcf1314d0963c5e336e11ad24bf735350a6a27352 (diff)
downloads6-linux-utils-6a9ae5d6fdc412d538f5fdd0c47c2b332336df35.tar.gz
s6-linux-utils-6a9ae5d6fdc412d538f5fdd0c47c2b332336df35.tar.xz
s6-linux-utils-6a9ae5d6fdc412d538f5fdd0c47c2b332336df35.zip
Separate sections for smaller static binaries (thanks Denys Vlasenko)
Diffstat (limited to 'configure')
-rwxr-xr-xconfigure6
1 files changed, 6 insertions, 0 deletions
diff --git a/configure b/configure
index 3ddb7e5..ab6a070 100755
--- a/configure
+++ b/configure
@@ -297,6 +297,11 @@ tryflag CPPFLAGS_AUTO -Werror=implicit-function-declaration
 tryflag CPPFLAGS_AUTO -Werror=implicit-int
 tryflag CPPFLAGS_AUTO -Werror=pointer-sign
 tryflag CPPFLAGS_AUTO -Werror=pointer-arith
+tryflag CFLAGS_AUTO -ffunction-sections
+tryflag CFLAGS_AUTO -fdata-sections
+
+tryldflag LDFLAGS_AUTO -Wl,--sort-section=alignment
+tryldflag LDFLAGS_AUTO -Wl,--sort-common
 
 if $evenmorestatic ; then
   LDFLAGS_NOSHARED=-static
@@ -310,6 +315,7 @@ LDFLAGS_SHARED="${LDFLAGS_SHARED}${addlibdpath}"
 
 if $allstatic ; then
   LDFLAGS_NOSHARED="${LDFLAGS_NOSHARED}${addlibspath}"
+  tryldflag LDFLAGS_NOSHARED -Wl,--gc-sections
 else
   LDFLAGS_NOSHARED="${LDFLAGS_NOSHARED}${addlibdpath}"
 fi