]> granicus.if.org Git - apache/commitdiff
Add an --enable-reduced-exports configure option to link libmain.a
authorJoe Orton <jorton@apache.org>
Thu, 20 Jun 2019 13:00:37 +0000 (13:00 +0000)
committerJoe Orton <jorton@apache.org>
Thu, 20 Jun 2019 13:00:37 +0000 (13:00 +0000)
using ld's --whole-archive mode and avoid building exports.c entirely.
This reduces the size of a minimal httpd binary by 18% on Linux/x86_64
(687K to 560K) with no difference to the set of symbols available to
modules.

This option is only appropriate to use if using a shared libapr*
build, hence is non-default.

* configure.in: Add --enable-reduced-exports; disable httpdunit build
  if used.  Define AP_FORCE_EXPORTS if not enabled (default) in place
  of AP_USING_AUTOCONF.

* server/main.c (ap_suck_in_APR): Only build if AP_FORCE_EXPORTS is
  defined.

* Makefile.in: Link libmain.la using LIBMAIN_LIB.

* server/Makefile.in: Conditionally build exports.c into libmain.

git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1861685 13f79535-47bb-0310-9956-ffa450edef68

Makefile.in
build/config_vars.sh.in
configure.in
server/Makefile.in
server/main.c

index ab137d1b67b0281551ec3c686e3a104437d3ab98..40c025a94cb8943e4a89dd70871d371210f15c22 100644 (file)
@@ -4,8 +4,13 @@ CLEAN_SUBDIRS = test
 
 PROGRAM_NAME         = $(progname)
 PROGRAM_SOURCES      = modules.c
-PROGRAM_LDADD        = buildmark.o $(HTTPD_LDFLAGS) $(PROGRAM_DEPENDENCIES) $(HTTPD_LIBS) $(EXTRA_LIBS) $(AP_LIBS) $(LIBS)
+PROGRAM_LDADD        = buildmark.o $(HTTPD_LDFLAGS) $(PROGRAM_LDDEPS) $(HTTPD_LIBS) $(EXTRA_LIBS) $(AP_LIBS) $(LIBS)
 PROGRAM_PRELINK      = $(COMPILE) -c $(top_srcdir)/server/buildmark.c
+PROGRAM_LDDEPS = \
+  $(BUILTIN_LIBS) \
+  $(MPM_LIB) \
+  $(LIBMAIN_LIB) \
+  os/$(OS_DIR)/libos.la
 PROGRAM_DEPENDENCIES = \
   $(BUILTIN_LIBS) \
   $(MPM_LIB) \
index 408e42d2cb1f5b4243dd02beddec490f615956c3..d586ebd4c50db42d8e9e1152625d4e306b0770d1 100644 (file)
@@ -84,4 +84,6 @@ exec sed "
 /^APR_INCLUDEDIR.*$/s,.*,APR_INCLUDEDIR = ${APR_INCLUDEDIR},
 /^APU_INCLUDEDIR.*$/s,.*,APU_INCLUDEDIR = ${APU_INCLUDEDIR},
 /^LIBTOOL.*$/s,/[^ ]*/libtool \(.*\),${APR_LIBTOOL} @LTFLAGS@,
+/^EXPORTS_DOT_C/d
+/^LIBMAIN_LIB/d
 "
index b20aad03f6a2dbafd8f4f7d116ec183df01e1f82..ec0336785e3d079fe4061173a1358410af84f51a 100644 (file)
@@ -703,6 +703,28 @@ fi
 APACHE_SUBST(PICFLAGS)
 APACHE_SUBST(PILDFLAGS)
 
+ap_reduced_exports=no
+EXPORTS_DOT_C=exports.c
+LIBMAIN_LIB=server/libmain.la
+APACHE_SUBST(EXPORTS_DOT_C)
+APACHE_SUBST(LIBMAIN_LIB)
+
+AC_ARG_ENABLE(reduced-exports,
+APACHE_HELP_STRING(--enable-reduced-exports,Reduce binary size if using shared APR libraries),
+[
+  if test "$enableval" = "yes" -a "$GCC" = "yes"; then
+    ap_reduced_exports=yes
+  fi
+])
+
+if test "$ap_reduced_exports" = "yes"; then
+  EXPORTS_DOT_C=
+  LIBMAIN_LIB="-Wl,--whole-archive,server/.libs/libmain.a,--no-whole-archive"
+  AC_MSG_NOTICE([Using reduced symbol exports])
+else
+  AC_DEFINE(AP_FORCE_EXPORTS, 1, [Force symbol exports for dependent libraries])
+fi
+
 AC_ARG_WITH(valgrind,
   [  --with-valgrind[[=DIR]]   Enable code to reduce valgrind false positives
                           (optionally: set path to valgrind headers) ],
@@ -722,7 +744,7 @@ AC_ARG_WITH(valgrind,
 dnl Enable the unit test executable if Check is installed.
 dnl TODO: at the moment, only pkg-config discovery is supported.
 AC_MSG_CHECKING([for Check to enable unit tests])
-if test "x$PKGCONFIG" != "x" && `$PKGCONFIG --atleast-version='0.9.12' check`; then
+if test "x$PKGCONFIG" != "x" -a "$AP_FORCE_EXPORTS" = "yes" && `$PKGCONFIG --atleast-version='0.9.12' check`; then
   UNITTEST_CFLAGS=`$PKGCONFIG --cflags check`
   UNITTEST_LIBS=`$PKGCONFIG --libs check`
   other_targets="$other_targets test/httpdunit"
@@ -864,9 +886,6 @@ APACHE_SUBST(AP_LIBS)
 APACHE_SUBST(AP_BUILD_SRCLIB_DIRS)
 APACHE_SUBST(AP_CLEAN_SRCLIB_DIRS)
 
-AC_DEFINE(AP_USING_AUTOCONF, 1,
-               [Using autoconf to configure Apache])
-
 if test "$SINGLE_LISTEN_UNSERIALIZED_ACCEPT" = "1"; then
     AC_DEFINE(SINGLE_LISTEN_UNSERIALIZED_ACCEPT, 1, 
               [This platform doesn't suffer from the thundering herd problem])
index e77efbacb9799b0578bc1f797da0730574e7b820..7786f656be33398e1e2d52403aafcadb671095d9 100644 (file)
@@ -12,7 +12,7 @@ LTLIBRARY_SOURCES = \
        connection.c listen.c util_mutex.c \
        mpm_common.c mpm_unix.c mpm_fdqueue.c \
        util_charset.c util_cookies.c util_debug.c util_xml.c \
-       util_filter.c util_pcre.c util_regex.c exports.c \
+       util_filter.c util_pcre.c util_regex.c $(EXPORTS_DOT_C) \
        scoreboard.c error_bucket.c protocol.c core.c request.c provider.c \
        eoc_bucket.c eor_bucket.c core_filters.c \
        util_expr_parse.c util_expr_scan.c util_expr_eval.c \
index a88085fe9f1f004a3df6068d11dbbb5a1e0fdec4..ac9e5dafd2c2e124aa53c772c6046683d6cda069 100644 (file)
@@ -861,7 +861,7 @@ static void usage(process_rec *process)
     return !OK;
 }
 
-#ifdef AP_USING_AUTOCONF
+#ifdef AP_FORCE_EXPORTS
 /* This ugly little hack pulls any function referenced in exports.c into
  * the web server.  exports.c is generated during the build, and it
  * has all of the APR functions specified by the apr/apr.exports and