diff -r 000000000000 -r 1918ee327afb src/3rdparty/ptmalloc/Makefile --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/3rdparty/ptmalloc/Makefile Mon Jan 11 14:00:40 2010 +0000 @@ -0,0 +1,211 @@ +# Makefile for ptmalloc, version 3 +# by Wolfram Gloger 1996-1999, 2001-2005, 2006 + +DIST_FILES0 = ChangeLog malloc-2.8.3.h malloc.c \ + malloc-private.h ptmalloc3.c \ + sysdeps \ + #tst-mallocstate.c tst-mstats.c +DIST_FILES1 = COPYRIGHT README Makefile \ + $(DIST_FILES0) \ + lran2.h t-test.h t-test1.c t-test2.c \ + tst-independent-alloc.c \ + #debian +DIST_FILES2 = $(DIST_FILES1) \ + m-test1.c \ + RCS/*,v + +TAR_FLAGS = --numeric-owner --exclude "*~" --exclude "debian/tmp*" + +#CC = /pkg/gcc-2.95.2-wg/bin/gcc +CC = gcc + +SYS_FLAGS = +OPT_FLAGS = -g -O2 #-O # -O2 +WARN_FLAGS = -Wall -Wstrict-prototypes +SH_FLAGS = -shared -fpic + +INC_FLAGS = -Isysdeps/generic + +# Flags for the test programs +T_FLAGS = -DUSE_MALLOC=1 -DTEST=1 + +# Flags for the compilation of malloc.c +M_FLAGS = -DTHREAD_STATS=1 #-DMALLOC_DEBUG=1 -DDEBUG=1 + +# Thread flags. +# See the platform-specific targets below. +THR_FLAGS = -DUSE_TSD_DATA_HACK -D_REENTRANT +THR_LIBS = -lpthread + +RM = rm -f +AR = ar +RANLIB = ranlib + +MALLOC_OBJ = ptmalloc3.o malloc.o +LIB_MALLOC = libptmalloc3.a + +T_SUF = +TESTS = t-test1$(T_SUF) t-test2$(T_SUF) \ + tst-independent-alloc$(T_SUF) + #m-test1$(T_SUF) tst-mallocstate$(T_SUF) tst-mstats$(T_SUF) + +CFLAGS = $(SYS_FLAGS) $(OPT_FLAGS) $(WARN_FLAGS) $(THR_FLAGS) $(INC_FLAGS) + +.c.o: + $(CC) -c $(CFLAGS) $< + +all: $(LIB_MALLOC) + +ptmalloc3.o: ptmalloc3.c malloc-2.8.3.h + $(CC) -c $(CFLAGS) $(M_FLAGS) -DMSPACES=1 $< + +malloc.o: malloc.c + $(CC) -c $(CFLAGS) $(M_FLAGS) -DONLY_MSPACES -DUSE_LOCKS=0 $< + +#malloc-stats.o: malloc-stats.c malloc.h +# $(CC) -c $(CFLAGS) $(M_FLAGS) $< + +libptmalloc3.a: $(MALLOC_OBJ) + $(AR) cr $@ $(MALLOC_OBJ) + $(RANLIB) $@ + +libptmalloc3.so: $(MALLOC_OBJ) + $(CC) $(SH_FLAGS) $(CFLAGS) $(M_FLAGS) $(MALLOC_OBJ) -o $@ + +again: + $(RM) $(TESTS) + $(MAKE) $(TESTS) + +clean: + $(RM) $(MALLOC_OBJ) libptmalloc3.a libptmalloc3.so $(TESTS) \ + core core.[0-9]* + +m-test1$(T_SUF): m-test1.c $(LIB_MALLOC) + $(CC) $(CFLAGS) $(T_FLAGS) m-test1.c $(LIB_MALLOC) $(THR_LIBS) -o $@ + +t-test1$(T_SUF): t-test1.c t-test.h $(LIB_MALLOC) + $(CC) $(CFLAGS) $(T_FLAGS) t-test1.c $(LIB_MALLOC) $(THR_LIBS) -o $@ + +t-test2$(T_SUF): t-test2.c t-test.h $(LIB_MALLOC) + $(CC) $(CFLAGS) $(T_FLAGS) t-test2.c $(LIB_MALLOC) $(THR_LIBS) -o $@ + +tst-mallocstate$(T_SUF): tst-mallocstate.c $(LIB_MALLOC) + $(CC) $(CFLAGS) $(T_FLAGS) tst-mallocstate.c $(LIB_MALLOC) \ + $(THR_LIBS) -o $@ + +tst-mstats$(T_SUF): tst-mstats.c $(LIB_MALLOC) + $(CC) $(CFLAGS) $(T_FLAGS) tst-mstats.c $(LIB_MALLOC) \ + $(THR_LIBS) -o $@ + +tst-independent-alloc$(T_SUF): tst-independent-alloc.c $(LIB_MALLOC) + $(CC) $(CFLAGS) $(T_FLAGS) tst-independent-alloc.c $(LIB_MALLOC) \ + $(THR_LIBS) -o $@ + +############################################################################ +# Platform-specific targets. The ones ending in `-libc' are provided +# to enable comparison with the standard malloc implementation from +# the system's native C library. The option USE_TSD_DATA_HACK is now +# the default for pthreads systems, as most (Irix 6, Solaris 2) seem +# to need it. Try with USE_TSD_DATA_HACK undefined only if you're +# confident that your systems's thread specific data functions do _not_ +# use malloc themselves. + +# posix threads with TSD data hack +posix: + $(MAKE) THR_FLAGS='-DUSE_TSD_DATA_HACK -D_REENTRANT' \ + OPT_FLAGS='$(OPT_FLAGS)' SYS_FLAGS='$(SYS_FLAGS)' CC='$(CC)' \ + INC_FLAGS='-Isysdeps/pthread -Isysdeps/generic -I.' + THR_LIBS=-lpthread + +# posix threads with explicit initialization. Known to be needed on HPUX. +posix-explicit: + $(MAKE) THR_FLAGS='-D_REENTRANT -DUSE_TSD_DATA_HACK -DUSE_STARTER=2' \ + THR_LIBS=-lpthread \ + OPT_FLAGS='$(OPT_FLAGS)' SYS_FLAGS='$(SYS_FLAGS)' CC='$(CC)' \ + INC_FLAGS='-Isysdeps/pthread -Isysdeps/generic -I.' \ + M_FLAGS='$(M_FLAGS)' + +# posix threads without TSD data hack -- not known to work +posix-with-tsd: + $(MAKE) THR_FLAGS='-D_REENTRANT' THR_LIBS=-lpthread \ + INC_FLAGS='-Isysdeps/pthread -Isysdeps/generic -I.' \ + M_FLAGS='$(M_FLAGS)' + +posix-libc: + $(MAKE) THR_FLAGS='-D_REENTRANT' THR_LIBS=-lpthread \ + INC_FLAGS='-Isysdeps/pthread -Isysdeps/generic -I.' \ + M_FLAGS='$(M_FLAGS)' LIB_MALLOC= T_FLAGS= T_SUF=-libc + +linux-pthread: + $(MAKE) SYS_FLAGS='-D_GNU_SOURCE=1' \ + WARN_FLAGS='-Wall -Wstrict-prototypes' \ + OPT_FLAGS='$(OPT_FLAGS)' THR_FLAGS='-DUSE_TSD_DATA_HACK' \ + INC_FLAGS='-Isysdeps/pthread -Isysdeps/generic -I.' M_FLAGS='$(M_FLAGS)' \ + TESTS='$(TESTS)' + +linux-shared: + $(MAKE) SYS_FLAGS='-D_GNU_SOURCE=1 -fpic' \ + WARN_FLAGS='-Wall -Wstrict-prototypes' \ + OPT_FLAGS='$(OPT_FLAGS)' THR_FLAGS='-DUSE_TSD_DATA_HACK' \ + INC_FLAGS='-Isysdeps/pthread -Isysdeps/generic -I.' M_FLAGS='$(M_FLAGS)' \ + LIB_MALLOC=libptmalloc3.so + +sproc: + $(MAKE) THR_FLAGS='' THR_LIBS='' OPT_FLAGS='$(OPT_FLAGS)' CC='$(CC)' \ + INC_FLAGS='-Isysdeps/sproc -Isysdeps/generic -I.' \ + M_FLAGS='$(M_FLAGS) -Dmalloc_getpagesize=4096' + +sproc-shared: + $(MAKE) THR_FLAGS='' THR_LIBS= \ + SH_FLAGS='-shared -check_registry /usr/lib/so_locations' \ + INC_FLAGS='-Isysdeps/sproc -Isysdeps/generic -I.' \ + LIB_MALLOC=libptmalloc3.so M_FLAGS='$(M_FLAGS)' + +sproc-libc: + $(MAKE) THR_FLAGS='' THR_LIBS= LIB_MALLOC= T_FLAGS= \ + INC_FLAGS='-Isysdeps/sproc -Isysdeps/generic -I.' \ + T_SUF=-libc M_FLAGS='$(M_FLAGS)' + +solaris: + $(MAKE) THR_FLAGS='-D_REENTRANT' OPT_FLAGS='$(OPT_FLAGS)' \ + INC_FLAGS='-Isysdeps/solaris -Isysdeps/generic -I.' \ + THR_LIBS=-lthread M_FLAGS='$(M_FLAGS)' + +solaris-libc: + $(MAKE) THR_FLAGS='-D_REENTRANT' OPT_FLAGS='$(OPT_FLAGS)' \ + INC_FLAGS='-Isysdeps/solaris -Isysdeps/generic -I.' \ + THR_LIBS=-lthread LIB_MALLOC= T_FLAGS= T_SUF=-libc M_FLAGS='$(M_FLAGS)' + +nothreads: + $(MAKE) OPT_FLAGS='$(OPT_FLAGS)' SYS_FLAGS='$(SYS_FLAGS)' \ + INC_FLAGS='-Isysdeps/generic -I.' \ + THR_FLAGS='' THR_LIBS='' M_FLAGS='$(M_FLAGS)' + +gcc-nothreads: + $(MAKE) CC='gcc' WARN_FLAGS='-Wall' OPT_FLAGS='$(OPT_FLAGS)' \ + INC_FLAGS='-Isysdeps/generic -I.' \ + SYS_FLAGS='$(SYS_FLAGS)' THR_FLAGS='' THR_LIBS='' M_FLAGS='$(M_FLAGS)' + +linux-nothreads: + $(MAKE) CC='gcc' WARN_FLAGS='-Wall' OPT_FLAGS='$(OPT_FLAGS)' \ + INC_FLAGS='-Isysdeps/generic -I.' \ + SYS_FLAGS='-D_GNU_SOURCE' THR_FLAGS='' THR_LIBS='' M_FLAGS='$(M_FLAGS)' + +############################################################################ + +check: $(TESTS) + ./t-test1 + ./t-test2 + #./tst-mallocstate || echo "Test mallocstate failed!" + #./tst-mstats || echo "Test mstats failed!" + +snap: + cd ..; tar $(TAR_FLAGS) -c -f - $(DIST_FILES1:%=ptmalloc3/%) | \ + gzip -9 >ptmalloc3-current.tar.gz + +dist: + cd ..; tar $(TAR_FLAGS) -c -f - $(DIST_FILES2:%=ptmalloc3/%) | \ + gzip -9 >ptmalloc3.tar.gz + +# dependencies +ptmalloc3.o: malloc-private.h