|
|
0e3136 |
|
|
|
0e3136 |
Reduce size of httpd binary by telling linker to export all symbols
|
|
|
0e3136 |
from libmain.a, rather than bloating the symbol table with ap_hack_*
|
|
|
0e3136 |
to do so indirectly.
|
|
|
0e3136 |
|
|
|
0e3136 |
Upstream: https://svn.apache.org/r1861685 (as new default-off configure option)
|
|
|
0e3136 |
|
|
|
0e3136 |
diff --git a/Makefile.in b/Makefile.in
|
|
|
0e3136 |
index 40c7076..ac98e5f 100644
|
|
|
0e3136 |
--- a/Makefile.in
|
|
|
0e3136 |
+++ b/Makefile.in
|
|
|
0e3136 |
@@ -4,8 +4,15 @@ CLEAN_SUBDIRS = test
|
|
|
0e3136 |
|
|
|
0e3136 |
PROGRAM_NAME = $(progname)
|
|
|
0e3136 |
PROGRAM_SOURCES = modules.c
|
|
|
0e3136 |
-PROGRAM_LDADD = buildmark.o $(HTTPD_LDFLAGS) $(PROGRAM_DEPENDENCIES) $(HTTPD_LIBS) $(EXTRA_LIBS) $(AP_LIBS) $(LIBS)
|
|
|
0e3136 |
+PROGRAM_LDADD = buildmark.o $(HTTPD_LDFLAGS) \
|
|
|
0e3136 |
+ $(PROGRAM_LDDEPS) \
|
|
|
0e3136 |
+ $(HTTPD_LIBS) $(EXTRA_LIBS) $(AP_LIBS) $(LIBS)
|
|
|
0e3136 |
PROGRAM_PRELINK = $(COMPILE) -c $(top_srcdir)/server/buildmark.c
|
|
|
0e3136 |
+PROGRAM_LDDEPS = \
|
|
|
0e3136 |
+ $(BUILTIN_LIBS) \
|
|
|
0e3136 |
+ $(MPM_LIB) \
|
|
|
0e3136 |
+ -Wl,--whole-archive,server/.libs/libmain.a,--no-whole-archive \
|
|
|
0e3136 |
+ os/$(OS_DIR)/libos.la
|
|
|
0e3136 |
PROGRAM_DEPENDENCIES = \
|
|
|
0e3136 |
server/libmain.la \
|
|
|
0e3136 |
$(BUILTIN_LIBS) \
|
|
|
0e3136 |
diff --git a/server/Makefile.in b/server/Makefile.in
|
|
|
0e3136 |
index 8111877..f00bb3f 100644
|
|
|
0e3136 |
--- a/server/Makefile.in
|
|
|
0e3136 |
+++ b/server/Makefile.in
|
|
|
0e3136 |
@@ -12,7 +12,7 @@ LTLIBRARY_SOURCES = \
|
|
|
0e3136 |
connection.c listen.c util_mutex.c \
|
|
|
0e3136 |
mpm_common.c mpm_unix.c mpm_fdqueue.c \
|
|
|
0e3136 |
util_charset.c util_cookies.c util_debug.c util_xml.c \
|
|
|
0e3136 |
- util_filter.c util_pcre.c util_regex.c exports.c \
|
|
|
0e3136 |
+ util_filter.c util_pcre.c util_regex.c \
|
|
|
0e3136 |
scoreboard.c error_bucket.c protocol.c core.c request.c ssl.c provider.c \
|
|
|
0e3136 |
eoc_bucket.c eor_bucket.c core_filters.c \
|
|
|
0e3136 |
util_expr_parse.c util_expr_scan.c util_expr_eval.c
|
|
|
0e3136 |
diff --git a/server/main.c b/server/main.c
|
|
|
0e3136 |
index 62e06df..17c09ee 100644
|
|
|
0e3136 |
--- a/server/main.c
|
|
|
0e3136 |
+++ b/server/main.c
|
|
|
0e3136 |
@@ -835,17 +835,3 @@ int main(int argc, const char * const argv[])
|
|
|
0e3136 |
return !OK;
|
|
|
0e3136 |
}
|
|
|
0e3136 |
|
|
|
0e3136 |
-#ifdef AP_USING_AUTOCONF
|
|
|
0e3136 |
-/* This ugly little hack pulls any function referenced in exports.c into
|
|
|
0e3136 |
- * the web server. exports.c is generated during the build, and it
|
|
|
0e3136 |
- * has all of the APR functions specified by the apr/apr.exports and
|
|
|
0e3136 |
- * apr-util/aprutil.exports files.
|
|
|
0e3136 |
- */
|
|
|
0e3136 |
-const void *ap_suck_in_APR(void);
|
|
|
0e3136 |
-const void *ap_suck_in_APR(void)
|
|
|
0e3136 |
-{
|
|
|
0e3136 |
- extern const void *ap_ugly_hack;
|
|
|
0e3136 |
-
|
|
|
0e3136 |
- return ap_ugly_hack;
|
|
|
0e3136 |
-}
|
|
|
0e3136 |
-#endif
|