]> git.saurik.com Git - redis.git/blobdiff - deps/jemalloc/Makefile.in
Sentinel: SENTINEL FAILOVER command implemented.
[redis.git] / deps / jemalloc / Makefile.in
index 26da0e28b26d67bc8c938c7b5364cc53ac3d3d2c..6675b59666173e624d99fbb91c6331187f295945 100644 (file)
@@ -17,129 +17,184 @@ INCLUDEDIR := $(DESTDIR)@INCLUDEDIR@
 LIBDIR := $(DESTDIR)@LIBDIR@
 DATADIR := $(DESTDIR)@DATADIR@
 MANDIR := $(DESTDIR)@MANDIR@
+srcroot := @srcroot@
+objroot := @objroot@
+abs_srcroot := @abs_srcroot@
+abs_objroot := @abs_objroot@
 
 # Build parameters.
-CPPFLAGS := @CPPFLAGS@ -I@srcroot@include -I@objroot@include
+CPPFLAGS := @CPPFLAGS@ -I$(srcroot)include -I$(objroot)include
 CFLAGS := @CFLAGS@
-ifeq (macho, @abi@)
-CFLAGS += -dynamic
-endif
 LDFLAGS := @LDFLAGS@
+EXTRA_LDFLAGS := @EXTRA_LDFLAGS@
 LIBS := @LIBS@
 RPATH_EXTRA := @RPATH_EXTRA@
-ifeq (macho, @abi@)
-SO := dylib
-WL_SONAME := dylib_install_name
+SO := @so@
+IMPORTLIB := @importlib@
+O := @o@
+A := @a@
+EXE := @exe@
+LIBPREFIX := @libprefix@
+REV := @rev@
+install_suffix := @install_suffix@
+ABI := @abi@
+XSLTPROC := @XSLTPROC@
+AUTOCONF := @AUTOCONF@
+_RPATH = @RPATH@
+RPATH = $(if $(1),$(call _RPATH,$(1)))
+cfghdrs_in := @cfghdrs_in@
+cfghdrs_out := @cfghdrs_out@
+cfgoutputs_in := @cfgoutputs_in@
+cfgoutputs_out := @cfgoutputs_out@
+enable_autogen := @enable_autogen@
+enable_experimental := @enable_experimental@
+DSO_LDFLAGS = @DSO_LDFLAGS@
+SOREV = @SOREV@
+PIC_CFLAGS = @PIC_CFLAGS@
+CTARGET = @CTARGET@
+LDTARGET = @LDTARGET@
+MKLIB = @MKLIB@
+CC_MM = @CC_MM@
+
+ifeq (macho, $(ABI))
+TEST_LIBRARY_PATH := DYLD_FALLBACK_LIBRARY_PATH="$(objroot)lib"
 else
-SO := so
-WL_SONAME := soname
-endif
-REV := 1
-ifeq (macho, @abi@)
-TEST_LIBRARY_PATH := DYLD_FALLBACK_LIBRARY_PATH=@objroot@lib
+ifeq (pecoff, $(ABI))
+TEST_LIBRARY_PATH := PATH="$(PATH):$(objroot)lib"
 else
 TEST_LIBRARY_PATH :=
 endif
+endif
+
+LIBJEMALLOC := $(LIBPREFIX)jemalloc$(install_suffix)
 
 # Lists of files.
-BINS := @srcroot@bin/pprof
-CHDRS := @objroot@include/jemalloc/jemalloc@install_suffix@.h \
-       @objroot@include/jemalloc/jemalloc_defs@install_suffix@.h
-CSRCS := @srcroot@src/jemalloc.c @srcroot@src/arena.c @srcroot@src/atomic.c \
-       @srcroot@src/base.c @srcroot@src/bitmap.c @srcroot@src/chunk.c \
-       @srcroot@src/chunk_dss.c @srcroot@src/chunk_mmap.c \
-       @srcroot@src/chunk_swap.c @srcroot@src/ckh.c @srcroot@src/ctl.c \
-       @srcroot@src/extent.c @srcroot@src/hash.c @srcroot@src/huge.c \
-       @srcroot@src/mb.c @srcroot@src/mutex.c @srcroot@src/prof.c \
-       @srcroot@src/rtree.c @srcroot@src/stats.c @srcroot@src/tcache.c
-ifeq (macho, @abi@)
-CSRCS += @srcroot@src/zone.c
+BINS := $(srcroot)bin/pprof $(objroot)bin/jemalloc.sh
+CHDRS := $(objroot)include/jemalloc/jemalloc$(install_suffix).h \
+       $(objroot)include/jemalloc/jemalloc_defs$(install_suffix).h
+CSRCS := $(srcroot)src/jemalloc.c $(srcroot)src/arena.c $(srcroot)src/atomic.c \
+       $(srcroot)src/base.c $(srcroot)src/bitmap.c $(srcroot)src/chunk.c \
+       $(srcroot)src/chunk_dss.c $(srcroot)src/chunk_mmap.c \
+       $(srcroot)src/ckh.c $(srcroot)src/ctl.c $(srcroot)src/extent.c \
+       $(srcroot)src/hash.c $(srcroot)src/huge.c $(srcroot)src/mb.c \
+       $(srcroot)src/mutex.c $(srcroot)src/prof.c $(srcroot)src/quarantine.c \
+       $(srcroot)src/rtree.c $(srcroot)src/stats.c $(srcroot)src/tcache.c \
+       $(srcroot)src/util.c $(srcroot)src/tsd.c
+ifeq (macho, $(ABI))
+CSRCS += $(srcroot)src/zone.c
+endif
+ifeq ($(IMPORTLIB),$(SO))
+STATIC_LIBS := $(objroot)lib/$(LIBJEMALLOC).$(A)
+endif
+ifdef PIC_CFLAGS
+STATIC_LIBS += $(objroot)lib/$(LIBJEMALLOC)_pic.$(A)
+else
+STATIC_LIBS += $(objroot)lib/$(LIBJEMALLOC)_s.$(A)
 endif
-STATIC_LIBS := @objroot@lib/libjemalloc@install_suffix@.a
-DSOS := @objroot@lib/libjemalloc@install_suffix@.$(SO).$(REV) \
-       @objroot@lib/libjemalloc@install_suffix@.$(SO) \
-       @objroot@lib/libjemalloc@install_suffix@_pic.a
-MAN3 := @objroot@doc/jemalloc@install_suffix@.3
-DOCS_XML := @objroot@doc/jemalloc@install_suffix@.xml
-DOCS_HTML := $(DOCS_XML:@objroot@%.xml=@srcroot@%.html)
-DOCS_MAN3 := $(DOCS_XML:@objroot@%.xml=@srcroot@%.3)
+DSOS := $(objroot)lib/$(LIBJEMALLOC).$(SOREV)
+ifneq ($(SOREV),$(SO))
+DSOS += $(objroot)lib/$(LIBJEMALLOC).$(SO)
+endif
+MAN3 := $(objroot)doc/jemalloc$(install_suffix).3
+DOCS_XML := $(objroot)doc/jemalloc$(install_suffix).xml
+DOCS_HTML := $(DOCS_XML:$(objroot)%.xml=$(srcroot)%.html)
+DOCS_MAN3 := $(DOCS_XML:$(objroot)%.xml=$(srcroot)%.3)
 DOCS := $(DOCS_HTML) $(DOCS_MAN3)
-CTESTS := @srcroot@test/allocated.c @srcroot@test/allocm.c \
-       @srcroot@test/bitmap.c @srcroot@test/mremap.c \
-       @srcroot@test/posix_memalign.c @srcroot@test/rallocm.c \
-       @srcroot@test/thread_arena.c
+CTESTS := $(srcroot)test/aligned_alloc.c $(srcroot)test/allocated.c \
+       $(srcroot)test/bitmap.c $(srcroot)test/mremap.c \
+       $(srcroot)test/posix_memalign.c $(srcroot)test/thread_arena.c \
+       $(srcroot)test/thread_tcache_enabled.c
+ifeq ($(enable_experimental), 1)
+CTESTS += $(srcroot)test/allocm.c $(srcroot)test/rallocm.c
+endif
+
+COBJS := $(CSRCS:$(srcroot)%.c=$(objroot)%.$(O))
+CPICOBJS := $(CSRCS:$(srcroot)%.c=$(objroot)%.pic.$(O))
+CTESTOBJS := $(CTESTS:$(srcroot)%.c=$(objroot)%.$(O))
 
 .PHONY: all dist doc_html doc_man doc
 .PHONY: install_bin install_include install_lib
 .PHONY: install_html install_man install_doc install
 .PHONY: tests check clean distclean relclean
 
-.SECONDARY : $(CTESTS:@srcroot@%.c=@objroot@%.o)
+.SECONDARY : $(CTESTOBJS)
 
 # Default target.
-all: $(DSOS) $(STATIC_LIBS)
+all: build
 
-dist: doc
+dist: build_doc
 
-@srcroot@doc/%.html : @objroot@doc/%.xml @srcroot@doc/stylesheet.xsl @objroot@doc/html.xsl
-       @XSLTPROC@ -o $@ @objroot@doc/html.xsl $<
+$(srcroot)doc/%.html : $(objroot)doc/%.xml $(srcroot)doc/stylesheet.xsl $(objroot)doc/html.xsl
+       $(XSLTPROC) -o $@ $(objroot)doc/html.xsl $<
 
-@srcroot@doc/%.3 : @objroot@doc/%.xml @srcroot@doc/stylesheet.xsl @objroot@doc/manpages.xsl
-       @XSLTPROC@ -o $@ @objroot@doc/manpages.xsl $<
+$(srcroot)doc/%.3 : $(objroot)doc/%.xml $(srcroot)doc/stylesheet.xsl $(objroot)doc/manpages.xsl
+       $(XSLTPROC) -o $@ $(objroot)doc/manpages.xsl $<
 
-doc_html: $(DOCS_HTML)
-doc_man: $(DOCS_MAN3)
-doc: $(DOCS)
+build_doc_html: $(DOCS_HTML)
+build_doc_man: $(DOCS_MAN3)
+build_doc: $(DOCS)
 
 #
 # Include generated dependency files.
 #
--include $(CSRCS:@srcroot@%.c=@objroot@%.d)
--include $(CSRCS:@srcroot@%.c=@objroot@%.pic.d)
--include $(CTESTS:@srcroot@%.c=@objroot@%.d)
+ifdef CC_MM
+-include $(COBJS:%.$(O)=%.d)
+-include $(CPICOBJS:%.$(O)=%.d)
+-include $(CTESTOBJS:%.$(O)=%.d)
+endif
 
-@objroot@src/%.o: @srcroot@src/%.c
-       @mkdir -p $(@D)
-       $(CC) $(CFLAGS) -c $(CPPFLAGS) -o $@ $<
-       @$(SHELL) -ec "$(CC) -MM $(CPPFLAGS) $< | sed \"s/\($(subst /,\/,$(notdir $(basename $@)))\)\.o\([ :]*\)/$(subst /,\/,$(strip $(dir $@)))\1.o \2/g\" > $(@:%.o=%.d)"
+$(COBJS): $(objroot)src/%.$(O): $(srcroot)src/%.c
+$(CPICOBJS): $(objroot)src/%.pic.$(O): $(srcroot)src/%.c
+$(CPICOBJS): CFLAGS += $(PIC_CFLAGS)
+$(CTESTOBJS): $(objroot)test/%.$(O): $(srcroot)test/%.c
+$(CTESTOBJS): CPPFLAGS += -I$(objroot)test
+ifneq ($(IMPORTLIB),$(SO))
+$(COBJS): CPPFLAGS += -DDLLEXPORT
+endif
 
-@objroot@src/%.pic.o: @srcroot@src/%.c
-       @mkdir -p $(@D)
-       $(CC) $(CFLAGS) -fPIC -DPIC -c $(CPPFLAGS) -o $@ $<
-       @$(SHELL) -ec "$(CC) -MM $(CPPFLAGS) $< | sed \"s/\($(subst /,\/,$(notdir $(basename $(basename $@))))\)\.o\([ :]*\)/$(subst /,\/,$(strip $(dir $@)))\1.pic.o \2/g\" > $(@:%.o=%.d)"
+ifndef CC_MM
+# Dependencies
+HEADER_DIRS = $(srcroot)include/jemalloc/internal \
+       $(objroot)include/jemalloc $(objroot)include/jemalloc/internal
+HEADERS = $(wildcard $(foreach dir,$(HEADER_DIRS),$(dir)/*.h))
+$(COBJS) $(CPICOBJS) $(CTESTOBJS): $(HEADERS)
+$(CTESTOBJS): $(objroot)test/jemalloc_test.h
+endif
 
-%.$(SO) : %.$(SO).$(REV)
+$(COBJS) $(CPICOBJS) $(CTESTOBJS): %.$(O):
        @mkdir -p $(@D)
-       ln -sf $(<F) $@
+       $(CC) $(CFLAGS) -c $(CPPFLAGS) $(CTARGET) $<
+ifdef CC_MM
+       @$(CC) -MM $(CPPFLAGS) -MT $@ -o $(@:%.$(O)=%.d) $<
+endif
 
-@objroot@lib/libjemalloc@install_suffix@.$(SO).$(REV) : $(CSRCS:@srcroot@%.c=@objroot@%.pic.o)
+ifneq ($(SOREV),$(SO))
+%.$(SO) : %.$(SOREV)
        @mkdir -p $(@D)
-       $(CC) -shared -Wl,-$(WL_SONAME),$(@F) $(RPATH_EXTRA:%=@RPATH@%) -o $@ $+ $(LDFLAGS) $(LIBS)
+       ln -sf $(<F) $@
+endif
 
-@objroot@lib/libjemalloc@install_suffix@_pic.a : $(CSRCS:@srcroot@%.c=@objroot@%.pic.o)
+$(objroot)lib/$(LIBJEMALLOC).$(SOREV) : $(if $(PIC_CFLAGS),$(CPICOBJS),$(COBJS))
        @mkdir -p $(@D)
-       ar crus $@ $+
+       $(CC) $(DSO_LDFLAGS) $(call RPATH,$(RPATH_EXTRA)) $(LDTARGET) $+ $(LDFLAGS) $(LIBS) $(EXTRA_LDFLAGS)
 
-@objroot@lib/libjemalloc@install_suffix@.a : $(CSRCS:@srcroot@%.c=@objroot@%.o)
-       @mkdir -p $(@D)
-       ar crus $@ $+
+$(objroot)lib/$(LIBJEMALLOC)_pic.$(A) : $(CPICOBJS)
+$(objroot)lib/$(LIBJEMALLOC).$(A) : $(COBJS)
+$(objroot)lib/$(LIBJEMALLOC)_s.$(A) : $(COBJS)
 
-@objroot@test/%.o: @srcroot@test/%.c
+$(STATIC_LIBS):
        @mkdir -p $(@D)
-       $(CC) $(CFLAGS) -c $(CPPFLAGS) -I@objroot@test -o $@ $<
-       @$(SHELL) -ec "$(CC) -MM $(CPPFLAGS) -I@objroot@test $< | sed \"s/\($(subst /,\/,$(notdir $(basename $@)))\)\.o\([ :]*\)/$(subst /,\/,$(strip $(dir $@)))\1.o \2/g\" > $(@:%.o=%.d)"
+       $(MKLIB) $+
 
-# Automatic dependency generation misses #include "*.c".
-@objroot@test/bitmap.o : @objroot@src/bitmap.o
+$(objroot)test/bitmap$(EXE): $(objroot)src/bitmap.$(O)
 
-@objroot@test/%: @objroot@test/%.o \
-                @objroot@lib/libjemalloc@install_suffix@.$(SO)
+$(objroot)test/%$(EXE): $(objroot)test/%.$(O) $(objroot)src/util.$(O) $(DSOS)
        @mkdir -p $(@D)
-ifneq (@RPATH@, )
-       $(CC) -o $@ $< @RPATH@@objroot@lib -L@objroot@lib -ljemalloc@install_suffix@
-else
-       $(CC) -o $@ $< -L@objroot@lib -ljemalloc@install_suffix@
-endif
+       $(CC) $(LDTARGET) $(filter %.$(O),$^) $(call RPATH,$(objroot)lib) $(objroot)lib/$(LIBJEMALLOC).$(IMPORTLIB) $(filter -lpthread,$(LIBS)) $(EXTRA_LDFLAGS)
+
+build_lib_shared: $(DSOS)
+build_lib_static: $(STATIC_LIBS)
+build: build_lib_shared build_lib_static
 
 install_bin:
        install -d $(BINDIR)
@@ -155,46 +210,55 @@ install_include:
        install -m 644 $$h $(INCLUDEDIR)/jemalloc; \
 done
 
-install_lib: $(DSOS) $(STATIC_LIBS)
+install_lib_shared: $(DSOS)
        install -d $(LIBDIR)
-       install -m 755 @objroot@lib/libjemalloc@install_suffix@.$(SO).$(REV) $(LIBDIR)
-       ln -sf libjemalloc@install_suffix@.$(SO).$(REV) $(LIBDIR)/libjemalloc@install_suffix@.$(SO)
-       install -m 755 @objroot@lib/libjemalloc@install_suffix@_pic.a $(LIBDIR)
-       install -m 755 @objroot@lib/libjemalloc@install_suffix@.a $(LIBDIR)
+       install -m 755 $(objroot)lib/$(LIBJEMALLOC).$(SOREV) $(LIBDIR)
+ifneq ($(SOREV),$(SO))
+       ln -sf $(LIBJEMALLOC).$(SOREV) $(LIBDIR)/$(LIBJEMALLOC).$(SO)
+endif
+
+install_lib_static: $(STATIC_LIBS)
+       install -d $(LIBDIR)
+       @for l in $(STATIC_LIBS); do \
+       echo "install -m 755 $$l $(LIBDIR)"; \
+       install -m 755 $$l $(LIBDIR); \
+done
+
+install_lib: install_lib_shared install_lib_static
 
-install_html:
-       install -d $(DATADIR)/doc/jemalloc@install_suffix@
+install_doc_html:
+       install -d $(DATADIR)/doc/jemalloc$(install_suffix)
        @for d in $(DOCS_HTML); do \
-       echo "install -m 644 $$d $(DATADIR)/doc/jemalloc@install_suffix@"; \
-       install -m 644 $$d $(DATADIR)/doc/jemalloc@install_suffix@; \
+       echo "install -m 644 $$d $(DATADIR)/doc/jemalloc$(install_suffix)"; \
+       install -m 644 $$d $(DATADIR)/doc/jemalloc$(install_suffix); \
 done
 
-install_man:
+install_doc_man:
        install -d $(MANDIR)/man3
        @for d in $(DOCS_MAN3); do \
        echo "install -m 644 $$d $(MANDIR)/man3"; \
        install -m 644 $$d $(MANDIR)/man3; \
 done
 
-install_doc: install_html install_man
+install_doc: install_doc_html install_doc_man
 
 install: install_bin install_include install_lib install_doc
 
-tests: $(CTESTS:@srcroot@%.c=@objroot@%)
+tests: $(CTESTS:$(srcroot)%.c=$(objroot)%$(EXE))
 
 check: tests
-       @mkdir -p @objroot@test
+       @mkdir -p $(objroot)test
        @$(SHELL) -c 'total=0; \
                failures=0; \
                echo "========================================="; \
-               for t in $(CTESTS:@srcroot@%.c=@objroot@%); do \
+               for t in $(CTESTS:$(srcroot)%.c=$(objroot)%); do \
                        total=`expr $$total + 1`; \
                        /bin/echo -n "$${t} ... "; \
-                       $(TEST_LIBRARY_PATH) $${t} @abs_srcroot@ @abs_objroot@ \
-                         > @objroot@$${t}.out 2>&1; \
-                       if test -e "@srcroot@$${t}.exp"; then \
-                               diff -u @srcroot@$${t}.exp \
-                                 @objroot@$${t}.out >/dev/null 2>&1; \
+                       $(TEST_LIBRARY_PATH) $${t}$(EXE) $(abs_srcroot) \
+                         $(abs_objroot) > $(objroot)$${t}.out 2>&1; \
+                       if test -e "$(srcroot)$${t}.exp"; then \
+                               diff -w -u $(srcroot)$${t}.exp \
+                                 $(objroot)$${t}.out >/dev/null 2>&1; \
                                fail=$$?; \
                                if test "$${fail}" -eq "1" ; then \
                                        failures=`expr $${failures} + 1`; \
@@ -211,49 +275,49 @@ check: tests
                echo "Failures: $${failures}/$${total}"'
 
 clean:
-       rm -f $(CSRCS:@srcroot@%.c=@objroot@%.o)
-       rm -f $(CSRCS:@srcroot@%.c=@objroot@%.pic.o)
-       rm -f $(CSRCS:@srcroot@%.c=@objroot@%.d)
-       rm -f $(CSRCS:@srcroot@%.c=@objroot@%.pic.d)
-       rm -f $(CTESTS:@srcroot@%.c=@objroot@%)
-       rm -f $(CTESTS:@srcroot@%.c=@objroot@%.o)
-       rm -f $(CTESTS:@srcroot@%.c=@objroot@%.d)
-       rm -f $(CTESTS:@srcroot@%.c=@objroot@%.out)
+       rm -f $(COBJS)
+       rm -f $(CPICOBJS)
+       rm -f $(COBJS:%.$(O)=%.d)
+       rm -f $(CPICOBJS:%.$(O)=%.d)
+       rm -f $(CTESTOBJS:%.$(O)=%$(EXE))
+       rm -f $(CTESTOBJS)
+       rm -f $(CTESTOBJS:%.$(O)=%.d)
+       rm -f $(CTESTOBJS:%.$(O)=%.out)
        rm -f $(DSOS) $(STATIC_LIBS)
 
 distclean: clean
-       rm -rf @objroot@autom4te.cache
-       rm -f @objroot@config.log
-       rm -f @objroot@config.status
-       rm -f @objroot@config.stamp
-       rm -f @cfghdrs_out@
-       rm -f @cfgoutputs_out@
+       rm -rf $(objroot)autom4te.cache
+       rm -f $(objroot)config.log
+       rm -f $(objroot)config.status
+       rm -f $(objroot)config.stamp
+       rm -f $(cfghdrs_out)
+       rm -f $(cfgoutputs_out)
 
 relclean: distclean
-       rm -f @objroot@configure
-       rm -f @srcroot@VERSION
+       rm -f $(objroot)configure
+       rm -f $(srcroot)VERSION
        rm -f $(DOCS_HTML)
        rm -f $(DOCS_MAN3)
 
 #===============================================================================
 # Re-configuration rules.
 
-ifeq (@enable_autogen@, 1)
-@srcroot@configure : @srcroot@configure.ac
-       cd ./@srcroot@ && @AUTOCONF@
+ifeq ($(enable_autogen), 1)
+$(srcroot)configure : $(srcroot)configure.ac
+       cd ./$(srcroot) && $(AUTOCONF)
 
-@objroot@config.status : @srcroot@configure
-       ./@objroot@config.status --recheck
+$(objroot)config.status : $(srcroot)configure
+       ./$(objroot)config.status --recheck
 
-@srcroot@config.stamp.in : @srcroot@configure.ac
-       echo stamp > @srcroot@config.stamp.in
+$(srcroot)config.stamp.in : $(srcroot)configure.ac
+       echo stamp > $(srcroot)config.stamp.in
 
-@objroot@config.stamp : @cfgoutputs_in@ @cfghdrs_in@ @srcroot@configure
-       ./@objroot@config.status
+$(objroot)config.stamp : $(cfgoutputs_in) $(cfghdrs_in) $(srcroot)configure
+       ./$(objroot)config.status
        @touch $@
 
 # There must be some action in order for make to re-read Makefile when it is
 # out of date.
-@cfgoutputs_out@ @cfghdrs_out@ : @objroot@config.stamp
+$(cfgoutputs_out) $(cfghdrs_out) : $(objroot)config.stamp
        @true
 endif