12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508 |
- ## Process this file with automake to produce Makefile.in
- # Note: for every library we create, we're explicit about what symbols
- # we export. In order to avoid complications with C++ mangling, we always
- # use the regexp for of specifying symbols.
- # Make sure that when we re-make ./configure, we get the macros we need
- ACLOCAL_AMFLAGS = -I m4
- AUTOMAKE_OPTIONS = subdir-objects
- # This is so we can #include <gperftools/foo>
- AM_CPPFLAGS = -I$(top_srcdir)/src
- if !WITH_STACK_TRACE
- AM_CPPFLAGS += -DNO_TCMALLOC_SAMPLES
- endif !WITH_STACK_TRACE
- # This is mostly based on configure options
- AM_CXXFLAGS =
- # These are good warnings to turn on by default.
- if GCC
- AM_CXXFLAGS += -Wall -Wwrite-strings -Woverloaded-virtual \
- -Wno-sign-compare
- # On i386, -mmmx is needed for the mmx-based instructions in
- # atomicops-internal-x86.h. Also as of gcc 4.6, -fomit-frame-pointer
- # is the default. Since we must always have frame pointers for I386
- # in order to generate backtraces we now specify -fno-omit-frame-pointer
- # by default.
- if I386
- AM_CXXFLAGS += -mmmx
- AM_CXXFLAGS += -fno-omit-frame-pointer
- endif I386
- endif GCC
- if HAVE_W_NO_UNUSED_RESULT
- AM_CXXFLAGS += -Wno-unused-result
- endif HAVE_W_NO_UNUSED_RESULT
- if HAVE_SIZED_DEALLOCATION
- AM_CXXFLAGS += -fsized-deallocation
- endif HAVE_SIZED_DEALLOCATION
- if HAVE_F_ALIGNED_NEW
- AM_CXXFLAGS += -faligned-new
- endif HAVE_F_ALIGNED_NEW
- # The -no-undefined flag allows libtool to generate shared libraries for
- # Cygwin and MinGW. LIBSTDCXX_LA_LINKER_FLAG is used to fix a Solaris bug.
- AM_LDFLAGS = -no-undefined $(LIBSTDCXX_LA_LINKER_FLAG)
- # These are x86-specific, having to do with frame-pointers. In
- # particular, some x86_64 systems do not insert frame pointers by
- # default (all i386 systems that I know of, do. I don't know about
- # non-x86 chips). We need to tell perftools what to do about that.
- if OMIT_FP_BY_DEFAULT
- if !ENABLE_FRAME_POINTERS
- AM_CXXFLAGS += -DNO_FRAME_POINTER
- endif !ENABLE_FRAME_POINTERS
- endif OMIT_FP_BY_DEFAULT
- # respect --enable-frame-pointers regardless of architecture
- if ENABLE_FRAME_POINTERS
- AM_CXXFLAGS += -fno-omit-frame-pointer
- endif ENABLE_FRAME_POINTERS
- # For windows systems (at least, mingw), we need to tell all our
- # tests to link in libtcmalloc using -u. This is because libtcmalloc
- # accomplishes its tasks via patching, leaving no work for the linker
- # to identify, so the linker will ignore libtcmalloc by default unless
- # we explicitly create a dependency via -u.
- TCMALLOC_FLAGS =
- if MINGW
- TCMALLOC_FLAGS += -Wl,-u__tcmalloc
- endif MINGW
- # If we have objcopy, make malloc/free/etc weak symbols. That way folks
- # can override our malloc if they want to (they can still use tc_malloc).
- # Note: the weird-looking symbols are the c++ memory functions:
- # (in order) new, new(nothrow), new[], new[](nothrow), delete, delete[]
- # In theory this will break if mangling changes, but that seems pretty
- # unlikely at this point. Just in case, I throw in versions with an
- # extra underscore as well, which may help on OS X.
- if HAVE_OBJCOPY_WEAKEN
- WEAKEN = $(OBJCOPY) -W malloc -W free -W realloc -W calloc -W cfree \
- -W memalign -W posix_memalign -W valloc -W pvalloc \
- -W aligned_alloc \
- -W malloc_stats -W mallopt -W mallinfo -W nallocx \
- -W _Znwm -W _ZnwmRKSt9nothrow_t -W _Znam -W _ZnamRKSt9nothrow_t \
- -W _ZdlPv -W _ZdaPv \
- -W __Znwm -W __ZnwmRKSt9nothrow_t -W __Znam -W __ZnamRKSt9nothrow_t \
- -W __ZdlPv -W __ZdaPv
- else
- WEAKEN = :
- endif !HAVE_OBJCOPY_WEAKEN
- LIBS_TO_WEAKEN =
- perftoolsincludedir = $(includedir)/gperftools
- # The .h files you want to install (that is, .h files that people
- # who install this package can include in their own applications.)
- # We'll add to this later, on a library-by-library basis
- perftoolsinclude_HEADERS =
- # tcmalloc.h is a special case, because it's a .h.in file
- nodist_perftoolsinclude_HEADERS = src/gperftools/tcmalloc.h
- noinst_HEADERS = src/gperftools/tcmalloc.h.in
- # This is provided for backwards compatibility. It is populated by
- # files that just forward to the canonical location in
- # perftoolsincludedir.
- googleincludedir = $(includedir)/google
- googleinclude_HEADERS = \
- src/google/heap-checker.h \
- src/google/heap-profiler.h \
- src/google/malloc_extension.h \
- src/google/malloc_extension_c.h \
- src/google/malloc_hook.h \
- src/google/malloc_hook_c.h \
- src/google/profiler.h \
- src/google/stacktrace.h \
- src/google/tcmalloc.h
- # This is for HTML and other documentation you want to install.
- # Add your documentation files (in doc/) in addition to these
- # top-level boilerplate files. Also add a TODO file if you have one.
- # We'll add to this later, on a library-by-library basis
- dist_doc_DATA = AUTHORS COPYING ChangeLog INSTALL NEWS README README_windows.txt \
- TODO ChangeLog.old
- # The libraries (.so's) you want to install
- # We'll add to this later, on a library-by-library basis
- lib_LTLIBRARIES =
- # This is for 'convenience libraries' -- basically just a container for sources
- noinst_LTLIBRARIES =
- ## The location of the windows project file for each binary we make
- WINDOWS_PROJECTS = gperftools.sln
- # unittests you want to run when people type 'make check'.
- # Note: tests cannot take any arguments!
- # In theory, unittests that are scripts should be added to check_SCRIPTS
- # instead. But check_SCRIPTS is definitely a second-class testing mechanims:
- # it don't get TESTS_ENVIRONMENT, and it doesn't get success/failure counting
- # (in fact, a script failure aborts all the rest of the tests, even with -k).
- # So, for scripts, we add the script to tests, and also put in an empty
- # rule so automake doesn't try to build the script as a C binary.
- TESTS =
- # TESTS_ENVIRONMENT sets environment variables for when you run unittest.
- # We always get "srcdir" set for free.
- # We'll add to this later, on a library-by-library basis.
- TESTS_ENVIRONMENT =
- # All script tests should be added here
- noinst_SCRIPTS =
- # If your test calls another program that, like the test itself, shouldn't
- # be installed, add it here. (Stuff in TESTS is automatically added later).
- noinst_PROGRAMS =
- # Binaries we might build that should be installed
- bin_PROGRAMS =
- # This is my own var, used for extra libraries I make that I need installed
- EXTRA_INSTALL =
- ## vvvv RULES TO MAKE THE LIBRARIES, BINARIES, AND UNITTESTS
- dist_doc_DATA += docs/index.html docs/designstyle.css
- ### ------- library routines, in src/base
- # This is a 'convenience library' -- it's not actually installed or anything
- LOGGING_INCLUDES = src/base/logging.h \
- src/base/commandlineflags.h \
- src/base/basictypes.h \
- src/base/dynamic_annotations.h
- noinst_LTLIBRARIES += liblogging.la
- liblogging_la_SOURCES = src/base/logging.cc \
- src/base/dynamic_annotations.c \
- $(LOGGING_INCLUDES)
- SYSINFO_INCLUDES = src/base/sysinfo.h \
- src/getenv_safe.h \
- src/base/logging.h \
- src/base/commandlineflags.h \
- src/base/arm_instruction_set_select.h \
- src/base/basictypes.h
- noinst_LTLIBRARIES += libsysinfo.la
- libsysinfo_la_SOURCES = src/base/sysinfo.cc \
- $(SYSINFO_INCLUDES)
- libsysinfo_la_LIBADD = $(NANOSLEEP_LIBS)
- noinst_LTLIBRARIES += libmaybe_threads.la
- # .cc is conditionally added below
- libmaybe_threads_la_SOURCES = src/maybe_threads.h
- # For MinGW, we use also have to use libwindows Luckily, we need the
- # windows.a library in exactly the same place we need spinlock.a
- # (pretty much everywhere), so we can use the same variable name for
- # each. We can also optimize the MinGW rule a bit by leaving out
- # files we know aren't used on windows, such as
- # atomicops-internals-x86.cc. libwindows also obsoletes the need for
- # other files like system_alloc.cc.
- if MINGW
- WINDOWS_INCLUDES = src/windows/port.h \
- src/windows/mingw.h \
- src/windows/mini_disassembler.h \
- src/windows/mini_disassembler_types.h \
- src/windows/preamble_patcher.h
- noinst_LTLIBRARIES += libwindows.la
- libwindows_la_SOURCES = $(WINDOWS_INCLUDES) \
- src/windows/port.cc \
- src/windows/system-alloc.cc \
- src/windows/ia32_modrm_map.cc \
- src/windows/ia32_opcode_map.cc \
- src/windows/mini_disassembler.cc \
- src/windows/patch_functions.cc \
- src/windows/preamble_patcher.cc \
- src/windows/preamble_patcher_with_stub.cc
- # patch_functions.cc uses Psapi.lib. MSVC has a #pragma for that, but not us.
- libwindows_la_LIBADD = -lpsapi
- SPINLOCK_INCLUDES = src/base/spinlock.h \
- src/base/spinlock_internal.h \
- src/base/spinlock_win32-inl.h \
- src/base/spinlock_linux-inl.h \
- src/base/spinlock_posix-inl.h \
- src/base/atomicops-internals-macosx.h \
- src/base/atomicops-internals-linuxppc.h \
- src/base/atomicops-internals-arm-generic.h \
- src/base/atomicops-internals-arm-v6plus.h \
- src/base/atomicops-internals-mips.h \
- src/base/atomicops-internals-windows.h \
- src/base/atomicops-internals-gcc.h \
- src/base/atomicops-internals-x86.h
- noinst_LTLIBRARIES += libspinlock.la
- libspinlock_la_SOURCES = src/base/spinlock.cc \
- src/base/spinlock_internal.cc \
- src/base/atomicops-internals-x86.cc \
- $(SPINLOCK_INCLUDES)
- LIBSPINLOCK = libwindows.la libspinlock.la libsysinfo.la liblogging.la
- # We also need to tell mingw that sysinfo.cc needs shlwapi.lib.
- # (We do this via a #pragma for msvc, but need to do it here for mingw).
- libsysinfo_la_LIBADD += -lshlwapi
- # There's a windows-specific unittest we can run. Right now it's
- # win64-specific, and relies on masm, so we comment it out.
- ## TESTS += preamble_patcher_test
- ## preamble_patcher_test_SOURCES = src/windows/preamble_patcher_test.cc \
- ## src/windows/shortproc.asm \
- ## src/windows/auto_testing_hook.h \
- ## src/windows/preamble_patcher.h \
- ## src/base/basictypes.h \
- ## src/base/logging.h
- ## preamble_patcher_test_LDFLAGS = $(TCMALLOC_FLAGS)
- ## preamble_patcher_test_LDADD = $(LIBTCMALLOC_MINIMAL)
- # patch_functions.cc #includes tcmalloc.cc, so no need to link it in.
- TCMALLOC_CC =
- # windows has its own system for threads and system memory allocation.
- if HAVE_PTHREAD_DESPITE_ASKING_FOR
- libmaybe_threads_la_SOURCES += src/maybe_threads.cc
- endif
- SYSTEM_ALLOC_CC =
- else !MINGW
- # spinlock is the only code that uses atomicops.
- SPINLOCK_INCLUDES = src/base/spinlock.h \
- src/base/spinlock_internal.h \
- src/base/atomicops.h \
- src/base/atomicops-internals-macosx.h \
- src/base/atomicops-internals-linuxppc.h \
- src/base/atomicops-internals-windows.h \
- src/base/atomicops-internals-x86.h
- noinst_LTLIBRARIES += libspinlock.la
- libspinlock_la_SOURCES = src/base/spinlock.cc \
- src/base/spinlock_internal.cc \
- src/base/atomicops-internals-x86.cc \
- $(SPINLOCK_INCLUDES)
- libspinlock_la_LIBADD = $(NANOSLEEP_LIBS)
- # spinlock also needs NumCPUs, from libsysinfo, which in turn needs liblogging
- LIBSPINLOCK = libspinlock.la libsysinfo.la liblogging.la
- TCMALLOC_CC = src/tcmalloc.cc
- libmaybe_threads_la_SOURCES += src/maybe_threads.cc
- SYSTEM_ALLOC_CC = src/system-alloc.cc
- endif !MINGW
- # Add this whether or not we're under MinGW, to keep the tarball complete.
- WINDOWS_PROJECTS += vsprojects/preamble_patcher_test/preamble_patcher_test.vcxproj
- # Because we've commented out the test, above, we have to explicitly add
- # the test files to the tarball or automake will leave them out.
- WINDOWS_PROJECTS += src/windows/preamble_patcher_test.cc \
- src/windows/shortproc.asm \
- src/windows/auto_testing_hook.h
- ### Unittests
- TESTS += low_level_alloc_unittest
- WINDOWS_PROJECTS += vsprojects/low_level_alloc_unittest/low_level_alloc_unittest.vcxproj
- LOW_LEVEL_ALLOC_UNITTEST_INCLUDES = src/base/low_level_alloc.h \
- src/base/basictypes.h \
- src/gperftools/malloc_hook.h \
- src/gperftools/malloc_hook_c.h \
- src/malloc_hook-inl.h \
- src/malloc_hook_mmap_linux.h \
- src/malloc_hook_mmap_freebsd.h \
- $(SPINLOCK_INCLUDES) \
- $(LOGGING_INCLUDES)
- low_level_alloc_unittest_SOURCES = src/base/low_level_alloc.cc \
- src/malloc_hook.cc \
- src/tests/low_level_alloc_unittest.cc \
- $(LOW_LEVEL_ALLOC_UNITTEST_INCLUDES)
- # By default, MallocHook takes stack traces for use by the heap-checker.
- # We don't need that functionality here, so we turn it off to reduce deps.
- low_level_alloc_unittest_CXXFLAGS = -DNO_TCMALLOC_SAMPLES
- low_level_alloc_unittest_LDADD = $(LIBSPINLOCK) libmaybe_threads.la
- TESTS += atomicops_unittest
- ATOMICOPS_UNITTEST_INCLUDES = src/base/atomicops.h \
- src/base/atomicops-internals-macosx.h \
- src/base/atomicops-internals-windows.h \
- src/base/atomicops-internals-x86.h \
- $(LOGGING_INCLUDES)
- atomicops_unittest_SOURCES = src/tests/atomicops_unittest.cc \
- $(ATOMICOPS_UNITTEST_INCLUDES)
- atomicops_unittest_LDADD = $(LIBSPINLOCK)
- ### ------- stack trace
- if WITH_STACK_TRACE
- ### The header files we use. We divide into categories based on directory
- S_STACKTRACE_INCLUDES = src/stacktrace_impl_setup-inl.h \
- src/stacktrace_generic-inl.h \
- src/stacktrace_generic_fp-inl.h \
- src/stacktrace_libgcc-inl.h \
- src/stacktrace_libunwind-inl.h \
- src/stacktrace_arm-inl.h \
- src/stacktrace_powerpc-inl.h \
- src/stacktrace_powerpc-darwin-inl.h \
- src/stacktrace_powerpc-linux-inl.h \
- src/stacktrace_x86-inl.h \
- src/stacktrace_win32-inl.h \
- src/stacktrace_instrument-inl.h \
- src/base/elf_mem_image.h \
- src/base/vdso_support.h
- SG_STACKTRACE_INCLUDES = src/gperftools/stacktrace.h
- STACKTRACE_INCLUDES = $(S_STACKTRACE_INCLUDES) $(SG_STACKTRACE_INCLUDES)
- perftoolsinclude_HEADERS += $(SG_STACKTRACE_INCLUDES)
- ### Making the library
- noinst_LTLIBRARIES += libstacktrace.la
- libstacktrace_la_SOURCES = src/stacktrace.cc \
- src/base/elf_mem_image.cc \
- src/base/vdso_support.cc \
- $(STACKTRACE_INCLUDES)
- libstacktrace_la_LIBADD = $(UNWIND_LIBS) $(LIBSPINLOCK)
- STACKTRACE_SYMBOLS = '(GetStackTrace|GetStackFrames|GetStackTraceWithContext|GetStackFramesWithContext)'
- libstacktrace_la_LDFLAGS = -export-symbols-regex $(STACKTRACE_SYMBOLS) $(AM_LDFLAGS)
- noinst_LTLIBRARIES += libfake_stacktrace_scope.la
- libfake_stacktrace_scope_la_SOURCES = src/fake_stacktrace_scope.cc
- ### Unittests
- TESTS += stacktrace_unittest
- STACKTRACE_UNITTEST_INCLUDES = src/config_for_unittests.h \
- src/base/commandlineflags.h \
- $(STACKTRACE_INCLUDES) \
- $(LOGGING_INCLUDES)
- stacktrace_unittest_SOURCES = src/tests/stacktrace_unittest.cc \
- $(STACKTRACE_UNITTEST_INCLUDES)
- stacktrace_unittest_LDADD = libstacktrace.la liblogging.la libfake_stacktrace_scope.la
- ### Documentation
- dist_doc_DATA +=
- endif WITH_STACK_TRACE
- ### ------- pprof
- # If we are not compiling with stacktrace support, pprof is worthless
- if WITH_STACK_TRACE
- bin_SCRIPTS = pprof-symbolize
- pprof-symbolize : $(top_srcdir)/src/pprof
- cp -p $(top_srcdir)/src/pprof $@
- ### Unittests
- check_SCRIPTS = pprof_unittest
- pprof_unittest: $(top_srcdir)/src/pprof
- $(top_srcdir)/src/pprof -test
- # Let unittests find pprof if they need to run it
- TESTS_ENVIRONMENT += PPROF_PATH=$(top_srcdir)/src/pprof
- if INSTALL_PPROF
- bin_SCRIPTS += src/pprof
- dist_man_MANS = docs/pprof.1
- dist_doc_DATA += docs/pprof_remote_servers.html
- endif INSTALL_PPROF
- ### Documentation
- # On MSVC, we need our own versions of addr2line and nm to work with pprof.
- WINDOWS_PROJECTS += vsprojects/nm-pdb/nm-pdb.vcxproj
- WINDOWS_PROJECTS += vsprojects/addr2line-pdb/addr2line-pdb.vcxproj
- # This is a slight abuse of WINDOWS_PROJECTS, but not much
- WINDOWS_PROJECTS += src/windows/nm-pdb.c \
- src/windows/addr2line-pdb.c
- endif WITH_STACK_TRACE
- ### ------- tcmalloc_minimal (thread-caching malloc)
- ### The header files we use. We divide into categories based on directory
- S_TCMALLOC_MINIMAL_INCLUDES = src/common.h \
- src/internal_logging.h \
- src/system-alloc.h \
- src/packed-cache-inl.h \
- $(SPINLOCK_INCLUDES) \
- src/tcmalloc_guard.h \
- src/base/commandlineflags.h \
- src/base/basictypes.h \
- src/pagemap.h \
- src/sampler.h \
- src/central_freelist.h \
- src/linked_list.h \
- src/libc_override.h \
- src/libc_override_gcc_and_weak.h \
- src/libc_override_glibc.h \
- src/libc_override_osx.h \
- src/libc_override_redefine.h \
- src/page_heap.h \
- src/page_heap_allocator.h \
- src/span.h \
- src/static_vars.h \
- src/symbolize.h \
- src/thread_cache.h \
- src/stack_trace_table.h \
- src/base/thread_annotations.h \
- src/malloc_hook-inl.h \
- src/malloc_hook_mmap_linux.h \
- src/malloc_hook_mmap_freebsd.h
- SG_TCMALLOC_MINIMAL_INCLUDES = src/gperftools/malloc_hook.h \
- src/gperftools/malloc_hook_c.h \
- src/gperftools/malloc_extension.h \
- src/gperftools/malloc_extension_c.h \
- src/gperftools/nallocx.h
- TCMALLOC_MINIMAL_INCLUDES = $(S_TCMALLOC_MINIMAL_INCLUDES) $(SG_TCMALLOC_MINIMAL_INCLUDES) $(SG_STACKTRACE_INCLUDES)
- perftoolsinclude_HEADERS += $(SG_TCMALLOC_MINIMAL_INCLUDES)
- ### Making the library
- noinst_LTLIBRARIES += libtcmalloc_minimal_internal.la
- libtcmalloc_minimal_internal_la_SOURCES = src/common.cc \
- src/internal_logging.cc \
- $(SYSTEM_ALLOC_CC) \
- src/memfs_malloc.cc \
- src/central_freelist.cc \
- src/page_heap.cc \
- src/sampler.cc \
- src/span.cc \
- src/stack_trace_table.cc \
- src/static_vars.cc \
- src/symbolize.cc \
- src/thread_cache.cc \
- src/malloc_hook.cc \
- src/malloc_extension.cc \
- $(TCMALLOC_MINIMAL_INCLUDES)
- # We #define NO_TCMALLOC_SAMPLES, since sampling is turned off for _minimal.
- libtcmalloc_minimal_internal_la_CXXFLAGS = -DNO_TCMALLOC_SAMPLES \
- -DNO_HEAP_CHECK \
- -DNDEBUG \
- $(AM_CXXFLAGS)
- libtcmalloc_minimal_internal_la_LDFLAGS = $(AM_LDFLAGS)
- libtcmalloc_minimal_internal_la_LIBADD = $(LIBSPINLOCK) libmaybe_threads.la
- lib_LTLIBRARIES += libtcmalloc_minimal.la
- WINDOWS_PROJECTS += vsprojects/libtcmalloc_minimal/libtcmalloc_minimal.vcxproj
- libtcmalloc_minimal_la_SOURCES = $(TCMALLOC_CC) $(TCMALLOC_MINIMAL_INCLUDES)
- libtcmalloc_minimal_la_CXXFLAGS = -DNO_TCMALLOC_SAMPLES \
- $(PTHREAD_CFLAGS) -DNDEBUG $(AM_CXXFLAGS)
- # -version-info gets passed to libtool
- libtcmalloc_minimal_la_LDFLAGS = -version-info @TCMALLOC_SO_VERSION@ $(AM_LDFLAGS)
- libtcmalloc_minimal_la_LIBADD = libtcmalloc_minimal_internal.la
- # For windows, we're playing around with trying to do some stacktrace
- # support even with libtcmalloc_minimal. For everyone else, though,
- # we turn off all stack-trace activity for libtcmalloc_minimal.
- # TODO(csilvers): when we're done experimenting, do something principled here
- if MINGW
- LIBTCMALLOC_MINIMAL = libtcmalloc_minimal.la libstacktrace.la
- else !MINGW
- LIBTCMALLOC_MINIMAL = libtcmalloc_minimal.la
- endif !MINGW
- LIBS_TO_WEAKEN += libtcmalloc_minimal.la
- ### Unittests
- # Commented out for the moment because malloc(very_big_num) is broken in
- # standard libc! At least, in some situations, some of the time.
- ## TESTS += malloc_unittest
- ## MALLOC_UNITEST_INCLUDES = src/gperftools/malloc_extension.h \
- ## src/gperftools/malloc_hook.h \
- ## src/gperftools/malloc_hook_c.h \
- ## src/malloc_hook-inl.h \
- ## src/malloc_hook_mmap_linux.h \
- ## src/malloc_hook_mmap_freebsd.h \
- ## src/base/basictypes.h \
- ## src/maybe_threads.h
- ## malloc_unittest_SOURCES = src/tests/tcmalloc_unittest.cc \
- ## src/malloc_hook.cc \
- ## src/malloc_extension.cc \
- ## $(MAYBE_THREADS_CC) \
- ## $(MALLOC_UNITTEST_INCLUDES)
- ## malloc_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- ## malloc_unittest_LDFLAGS = $(PTHREAD_CFLAGS)
- ## malloc_unittest_LDADD = $(PTHREAD_LIBS)
- TESTS += tcmalloc_minimal_unittest
- WINDOWS_PROJECTS += vsprojects/tcmalloc_minimal_unittest/tcmalloc_minimal_unittest.vcxproj
- tcmalloc_minimal_unittest_SOURCES = src/tests/tcmalloc_unittest.cc \
- src/tests/testutil.h src/tests/testutil.cc \
- $(TCMALLOC_UNITTEST_INCLUDES)
- tcmalloc_minimal_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- tcmalloc_minimal_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- # We want libtcmalloc last on the link line, but due to a bug in
- # libtool involving convenience libs, they need to come last on the
- # link line in order to get dependency ordering right. This is ok:
- # convenience libraries are .a's, so tcmalloc is still the last .so.
- # We also put pthreads after tcmalloc, because some pthread
- # implementations define their own malloc, and we need to go on the
- # first linkline to make sure our malloc 'wins'.
- tcmalloc_minimal_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) \
- liblogging.la $(PTHREAD_LIBS)
- # lets make sure we exerice ASSERTs in at least in statically linked
- # configuration
- TESTS += tcm_min_asserts_unittest
- tcm_min_asserts_unittest_SOURCES = src/tests/tcmalloc_unittest.cc \
- src/tests/testutil.h src/tests/testutil.cc \
- $(libtcmalloc_minimal_internal_la_SOURCES) \
- $(libtcmalloc_minimal_la_SOURCES) \
- $(TCMALLOC_UNITTEST_INCLUDES)
- tcm_min_asserts_unittest_CXXFLAGS = -DNO_TCMALLOC_SAMPLES -DNO_HEAP_CHECK \
- $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- tcm_min_asserts_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- tcm_min_asserts_unittest_LDADD = $(LIBSPINLOCK) libmaybe_threads.la \
- liblogging.la $(PTHREAD_LIBS)
- TESTS += tcmalloc_minimal_large_unittest
- WINDOWS_PROJECTS += vsprojects/tcmalloc_minimal_large/tcmalloc_minimal_large_unittest.vcxproj
- tcmalloc_minimal_large_unittest_SOURCES = src/tests/tcmalloc_large_unittest.cc
- tcmalloc_minimal_large_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- tcmalloc_minimal_large_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- tcmalloc_minimal_large_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += tcmalloc_minimal_large_heap_fragmentation_unittest
- tcmalloc_minimal_large_heap_fragmentation_unittest_SOURCES = src/tests/large_heap_fragmentation_unittest.cc
- tcmalloc_minimal_large_heap_fragmentation_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- tcmalloc_minimal_large_heap_fragmentation_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- tcmalloc_minimal_large_heap_fragmentation_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- # This tests it works to LD_PRELOAD libtcmalloc (tests maybe_threads.cc)
- # In theory this should work under mingw, but mingw has trouble running
- # shell scripts that end in .exe. And it doesn't seem to build shared
- # libraries anyway (so can't be LD_PRELOADed) -- in fact, anybody who
- # chooses not to build shared libraries won't be able to run this test.
- # TODO(csilvers): figure out how to nix ".exe" or otherwise work under mingw
- if !MINGW
- if !ENABLE_STATIC
- TESTS += maybe_threads_unittest.sh$(EXEEXT)
- maybe_threads_unittest_sh_SOURCES = src/tests/maybe_threads_unittest.sh
- noinst_SCRIPTS += $(maybe_threads_unittest_sh_SOURCES)
- # This script preloads libtcmalloc, and calls two other binaries as well
- # TODO(csilvers): replace by 'if ! cmp $^ $@ >/dev/null 2>&; then ...; fi'
- maybe_threads_unittest.sh$(EXEEXT): $(top_srcdir)/$(maybe_threads_unittest_sh_SOURCES) \
- $(LIBTCMALLOC_MINIMAL) \
- low_level_alloc_unittest
- rm -f $@
- cp -p $(top_srcdir)/$(maybe_threads_unittest_sh_SOURCES) $@
- endif !ENABLE_STATIC
- endif !MINGW
- # These all tests components of tcmalloc_minimal
- TESTS += addressmap_unittest
- WINDOWS_PROJECTS += vsprojects/addressmap_unittest/addressmap_unittest.vcxproj
- ADDRESSMAP_UNITTEST_INCLUDES = src/addressmap-inl.h \
- src/base/commandlineflags.h \
- $(LOGGING_INCLUDES)
- addressmap_unittest_SOURCES = src/tests/addressmap_unittest.cc \
- $(ADDRESSMAP_UNITTEST_INCLUDES)
- if MINGW
- addressmap_unittest_SOURCES += src/windows/port.h src/windows/port.cc
- endif MINGW
- addressmap_unittest_CXXFLAGS = -g $(AM_CXXFLAGS)
- addressmap_unittest_LDADD = liblogging.la
- WINDOWS_PROJECTS += vsprojects/system-alloc_unittest/system-alloc_unittest.vcxproj
- if !MINGW
- TESTS += system_alloc_unittest
- system_alloc_unittest_SOURCES = src/config_for_unittests.h \
- src/tests/system-alloc_unittest.cc
- system_alloc_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- system_alloc_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- system_alloc_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- endif !MINGW
- TESTS += packed_cache_test
- WINDOWS_PROJECTS += vsprojects/packed-cache_test/packed-cache_test.vcxproj
- packed_cache_test_SOURCES = src/tests/packed-cache_test.cc
- packed_cache_test_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- packed_cache_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- packed_cache_test_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += frag_unittest
- WINDOWS_PROJECTS += vsprojects/frag_unittest/frag_unittest.vcxproj
- frag_unittest_SOURCES = src/tests/frag_unittest.cc src/config_for_unittests.h
- frag_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- frag_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- frag_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += markidle_unittest
- WINDOWS_PROJECTS += vsprojects/markidle_unittest/markidle_unittest.vcxproj
- markidle_unittest_SOURCES = src/tests/markidle_unittest.cc \
- src/config_for_unittests.h \
- src/tests/testutil.h src/tests/testutil.cc
- markidle_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- markidle_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- markidle_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += current_allocated_bytes_test
- WINDOWS_PROJECTS += vsprojects/current_allocated_bytes_test/current_allocated_bytes_test.vcxproj
- current_allocated_bytes_test_SOURCES = src/tests/current_allocated_bytes_test.cc \
- src/config_for_unittests.h
- current_allocated_bytes_test_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- current_allocated_bytes_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- current_allocated_bytes_test_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += malloc_hook_test
- WINDOWS_PROJECTS += vsprojects/malloc_hook_test/malloc_hook_test.vcxproj
- malloc_hook_test_SOURCES = src/tests/malloc_hook_test.cc \
- src/config_for_unittests.h \
- src/base/logging.h \
- src/gperftools/malloc_hook.h \
- src/tests/testutil.h src/tests/testutil.cc
- malloc_hook_test_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- malloc_hook_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- malloc_hook_test_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += malloc_extension_test
- WINDOWS_PROJECTS += vsprojects/malloc_extension_test/malloc_extension_test.vcxproj
- malloc_extension_test_SOURCES = src/tests/malloc_extension_test.cc \
- src/config_for_unittests.h \
- src/base/logging.h \
- src/gperftools/malloc_extension.h \
- src/gperftools/malloc_extension_c.h
- malloc_extension_test_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- malloc_extension_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- malloc_extension_test_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- # This doesn't work with mingw, which links foo.a even though it
- # doesn't set ENABLE_STATIC. TODO(csilvers): set enable_static=true
- # in configure.ac:36?
- if !MINGW
- TESTS += malloc_extension_c_test
- malloc_extension_c_test_SOURCES = src/tests/malloc_extension_c_test.c \
- src/gperftools/malloc_extension.h \
- src/gperftools/malloc_extension_c.h
- malloc_extension_c_test_CFLAGS = $(PTHREAD_CFLAGS) $(AM_CFLAGS)
- # -ansi here is just to help ensure the code is bog-standard C.
- if GCC
- malloc_extension_c_test_CFLAGS += -ansi
- endif GCC
- malloc_extension_c_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- malloc_extension_c_test_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS) -lstdc++ -lm
- endif !MINGW
- if !MINGW
- if !OSX
- TESTS += memalign_unittest
- memalign_unittest_SOURCES = src/tests/memalign_unittest.cc \
- src/tcmalloc.h \
- src/config_for_unittests.h \
- src/tests/testutil.h src/tests/testutil.cc
- memalign_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- memalign_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- memalign_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- endif !OSX
- endif !MINGW
- TESTS += page_heap_test
- WINDOWS_PROJECTS += vsprojects/page_heap_test/page_heap_test.vcxproj
- page_heap_test_SOURCES = src/tests/page_heap_test.cc \
- src/config_for_unittests.h \
- src/base/logging.h \
- src/common.h \
- src/page_heap.h
- page_heap_test_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- page_heap_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- page_heap_test_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += pagemap_unittest
- WINDOWS_PROJECTS += vsprojects/pagemap_unittest/pagemap_unittest.vcxproj
- pagemap_unittest_SOURCES = src/tests/pagemap_unittest.cc \
- src/config_for_unittests.h \
- src/base/logging.h \
- src/pagemap.h
- pagemap_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- pagemap_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- pagemap_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += realloc_unittest
- WINDOWS_PROJECTS += vsprojects/realloc_unittest/realloc_unittest.vcxproj
- realloc_unittest_SOURCES = src/tests/realloc_unittest.cc \
- src/config_for_unittests.h \
- src/base/logging.h
- realloc_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- realloc_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- realloc_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += stack_trace_table_test
- WINDOWS_PROJECTS += vsprojects/stack_trace_table_test/stack_trace_table_test.vcxproj
- stack_trace_table_test_SOURCES = src/tests/stack_trace_table_test.cc \
- src/config_for_unittests.h
- stack_trace_table_test_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- stack_trace_table_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- stack_trace_table_test_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- TESTS += thread_dealloc_unittest
- WINDOWS_PROJECTS += vsprojects/thread_dealloc_unittest/thread_dealloc_unittest.vcxproj
- thread_dealloc_unittest_SOURCES = src/tests/thread_dealloc_unittest.cc \
- src/config_for_unittests.h \
- src/tests/testutil.h src/tests/testutil.cc
- thread_dealloc_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- thread_dealloc_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- thread_dealloc_unittest_LDADD = $(LIBTCMALLOC_MINIMAL) $(PTHREAD_LIBS)
- ### Documentation
- dist_doc_DATA += docs/tcmalloc.html \
- docs/overview.gif \
- docs/pageheap.gif \
- docs/spanmap.gif \
- docs/threadheap.gif \
- docs/t-test1.times.txt \
- docs/tcmalloc-opspercpusec.vs.threads.1024.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.128.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.131072.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.16384.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.2048.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.256.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.32768.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.4096.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.512.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.64.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.65536.bytes.png \
- docs/tcmalloc-opspercpusec.vs.threads.8192.bytes.png \
- docs/tcmalloc-opspersec.vs.size.1.threads.png \
- docs/tcmalloc-opspersec.vs.size.12.threads.png \
- docs/tcmalloc-opspersec.vs.size.16.threads.png \
- docs/tcmalloc-opspersec.vs.size.2.threads.png \
- docs/tcmalloc-opspersec.vs.size.20.threads.png \
- docs/tcmalloc-opspersec.vs.size.3.threads.png \
- docs/tcmalloc-opspersec.vs.size.4.threads.png \
- docs/tcmalloc-opspersec.vs.size.5.threads.png \
- docs/tcmalloc-opspersec.vs.size.8.threads.png
- # I don't know how to say "distribute the .dot files but don't install them";
- # noinst doesn't seem to work with data. I separate them out anyway, in case
- # one day we figure it out. Regardless, installing the dot files isn't the
- # end of the world.
- dist_doc_DATA += docs/overview.dot \
- docs/pageheap.dot \
- docs/spanmap.dot \
- docs/threadheap.dot
- ### ------- tcmalloc_minimal_debug (thread-caching malloc with debugallocation)
- if WITH_DEBUGALLOC
- lib_LTLIBRARIES += libtcmalloc_minimal_debug.la
- libtcmalloc_minimal_debug_la_SOURCES = src/debugallocation.cc \
- $(TCMALLOC_MINIMAL_INCLUDES)
- libtcmalloc_minimal_debug_la_CXXFLAGS = $(libtcmalloc_minimal_la_CXXFLAGS) \
- -DTCMALLOC_FOR_DEBUGALLOCATION
- # version_info gets passed to libtool
- libtcmalloc_minimal_debug_la_LDFLAGS = $(libtcmalloc_minimal_la_LDFLAGS) \
- -version-info @TCMALLOC_SO_VERSION@
- libtcmalloc_minimal_debug_la_LIBADD = $(libtcmalloc_minimal_la_LIBADD)
- LIBS_TO_WEAKEN += libtcmalloc_minimal_debug.la
- ### Unittests
- TESTS += tcmalloc_minimal_debug_unittest
- tcmalloc_minimal_debug_unittest_SOURCES = $(tcmalloc_minimal_unittest_SOURCES)
- tcmalloc_minimal_debug_unittest_CXXFLAGS = $(tcmalloc_minimal_unittest_CXXFLAGS) \
- -DDEBUGALLOCATION
- tcmalloc_minimal_debug_unittest_LDFLAGS = $(tcmalloc_minimal_unittest_LDFLAGS)
- tcmalloc_minimal_debug_unittest_LDADD = libtcmalloc_minimal_debug.la $(PTHREAD_LIBS)
- TESTS += malloc_extension_debug_test
- malloc_extension_debug_test_SOURCES = $(malloc_extension_test_SOURCES)
- malloc_extension_debug_test_CXXFLAGS = $(malloc_extension_test_CXXFLAGS)
- malloc_extension_debug_test_LDFLAGS = $(malloc_extension_test_LDFLAGS)
- malloc_extension_debug_test_LDADD = libtcmalloc_minimal_debug.la $(PTHREAD_LIBS)
- if !MINGW
- if !OSX
- TESTS += memalign_debug_unittest
- memalign_debug_unittest_SOURCES = $(memalign_unittest_SOURCES)
- memalign_debug_unittest_CXXFLAGS = $(memalign_unittest_CXXFLAGS)
- memalign_debug_unittest_LDFLAGS = $(memalign_unittest_LDFLAGS)
- memalign_debug_unittest_LDADD = libtcmalloc_minimal_debug.la $(PTHREAD_LIBS)
- endif !OSX
- endif !MINGW
- TESTS += realloc_debug_unittest
- realloc_debug_unittest_SOURCES = $(realloc_unittest_SOURCES)
- realloc_debug_unittest_CXXFLAGS = $(realloc_unittest_CXXFLAGS)
- realloc_debug_unittest_LDFLAGS = $(realloc_unittest_LDFLAGS)
- realloc_debug_unittest_LDADD = libtcmalloc_minimal_debug.la $(PTHREAD_LIBS)
- # debugallocation_test checks that we print a proper stacktrace when
- # debug-allocs fail, so we can't run it if we don't have stacktrace info.
- if WITH_STACK_TRACE
- TESTS += debugallocation_test.sh$(EXEEXT)
- debugallocation_test_sh_SOURCES = src/tests/debugallocation_test.sh
- noinst_SCRIPTS += $(debugallocation_test_sh_SOURCES)
- debugallocation_test.sh$(EXEEXT): $(top_srcdir)/$(debugallocation_test_sh_SOURCES) \
- debugallocation_test
- rm -f $@
- cp -p $(top_srcdir)/$(debugallocation_test_sh_SOURCES) $@
- # This is the sub-program used by debugallocation_test.sh
- noinst_PROGRAMS += debugallocation_test
- debugallocation_test_SOURCES = src/tests/debugallocation_test.cc
- debugallocation_test_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- debugallocation_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- debugallocation_test_LDADD = libtcmalloc_debug.la $(PTHREAD_LIBS)
- endif WITH_STACK_TRACE
- endif WITH_DEBUGALLOC
- if !MINGW
- noinst_LTLIBRARIES += librun_benchmark.la
- librun_benchmark_la_SOURCES = \
- benchmark/run_benchmark.c benchmark/run_benchmark.h
- noinst_PROGRAMS += malloc_bench malloc_bench_shared \
- binary_trees binary_trees_shared
- malloc_bench_SOURCES = benchmark/malloc_bench.cc
- malloc_bench_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- malloc_bench_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- if ENABLE_STATIC
- malloc_bench_LDFLAGS += -static
- endif ENABLE_STATIC
- malloc_bench_LDADD = librun_benchmark.la libtcmalloc_minimal.la $(PTHREAD_LIBS)
- malloc_bench_shared_SOURCES = benchmark/malloc_bench.cc
- malloc_bench_shared_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- malloc_bench_shared_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- malloc_bench_shared_LDADD = librun_benchmark.la libtcmalloc_minimal.la $(PTHREAD_LIBS)
- if WITH_HEAP_PROFILER_OR_CHECKER
- noinst_PROGRAMS += malloc_bench_shared_full
- malloc_bench_shared_full_SOURCES = benchmark/malloc_bench.cc
- malloc_bench_shared_full_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- malloc_bench_shared_full_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- malloc_bench_shared_full_LDADD = librun_benchmark.la libtcmalloc.la $(PTHREAD_LIBS)
- endif WITH_HEAP_PROFILER_OR_CHECKER
- binary_trees_SOURCES = benchmark/binary_trees.cc
- binary_trees_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- binary_trees_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- if ENABLE_STATIC
- binary_trees_LDFLAGS += -static
- endif ENABLE_STATIC
- binary_trees_LDADD = libtcmalloc_minimal.la $(PTHREAD_LIBS)
- binary_trees_shared_SOURCES = benchmark/binary_trees.cc
- binary_trees_shared_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- binary_trees_shared_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- binary_trees_shared_LDADD = libtcmalloc_minimal.la $(PTHREAD_LIBS)
- endif !MINGW
- ### ------- tcmalloc (thread-caching malloc + heap profiler + heap checker)
- if WITH_HEAP_PROFILER_OR_CHECKER
- ### The header files we use. We divide into categories based on directory
- S_TCMALLOC_INCLUDES = $(S_TCMALLOC_MINIMAL_INCLUDES) \
- $(LOGGING_INCLUDES) \
- src/addressmap-inl.h \
- src/raw_printer.h \
- src/base/elfcore.h \
- src/base/googleinit.h \
- src/base/linux_syscall_support.h \
- src/base/linuxthreads.h \
- src/base/stl_allocator.h \
- src/base/sysinfo.h \
- src/base/thread_lister.h \
- src/heap-profile-table.h \
- src/heap-profile-stats.h \
- src/maybe_emergency_malloc.h \
- src/emergency_malloc.h
- SG_TCMALLOC_INCLUDES = src/gperftools/heap-profiler.h \
- src/gperftools/heap-checker.h
- TCMALLOC_INCLUDES = $(S_TCMALLOC_INCLUDES) $(SG_TCMALLOC_MINIMAL_INCLUDES) \
- $(SG_TCMALLOC_INCLUDES) $(SG_STACKTRACE_INCLUDES)
- perftoolsinclude_HEADERS += $(SG_TCMALLOC_INCLUDES)
- if BUILD_EMERGENCY_MALLOC
- EMERGENCY_MALLOC_CC = src/emergency_malloc.cc src/emergency_malloc_for_stacktrace.cc
- EMERGENCY_MALLOC_DEFINE = -DENABLE_EMERGENCY_MALLOC
- else !BUILD_EMERGENCY_MALLOC
- EMERGENCY_MALLOC_CC = src/fake_stacktrace_scope.cc
- EMERGENCY_MALLOC_DEFINE =
- endif !BUILD_EMERGENCY_MALLOC
- ### Making the library
- if WITH_HEAP_CHECKER
- # heap-checker-bcad is last, in hopes its global ctor will run first.
- # (Note this is added to libtcmalloc.la, not libtcmalloc_internal.la,
- # but that's ok; the internal/external distinction is only useful for
- # cygwin, and cygwin doesn't use HEAP_CHECKER anyway.)
- HEAP_CHECKER_SOURCES = src/base/thread_lister.c \
- src/base/linuxthreads.cc \
- src/heap-checker.cc \
- src/heap-checker-bcad.cc
- MAYBE_NO_HEAP_CHECK =
- else !WITH_HEAP_CHECKER
- HEAP_CHECKER_SOURCES =
- MAYBE_NO_HEAP_CHECK = -DNO_HEAP_CHECK
- endif !WITH_HEAP_CHECKER
- noinst_LTLIBRARIES += libtcmalloc_internal.la
- libtcmalloc_internal_la_SOURCES = $(libtcmalloc_minimal_internal_la_SOURCES) \
- $(TCMALLOC_INCLUDES) \
- src/base/low_level_alloc.cc \
- src/heap-profile-table.cc \
- src/heap-profiler.cc \
- src/raw_printer.cc \
- $(EMERGENCY_MALLOC_CC) \
- src/memory_region_map.cc
- libtcmalloc_internal_la_CXXFLAGS = $(PTHREAD_CFLAGS) -DNDEBUG \
- $(AM_CXXFLAGS) $(EMERGENCY_MALLOC_DEFINE) \
- $(MAYBE_NO_HEAP_CHECK)
- libtcmalloc_internal_la_LDFLAGS = $(PTHREAD_CFLAGS)
- libtcmalloc_internal_la_LIBADD = libstacktrace.la $(PTHREAD_LIBS)
- lib_LTLIBRARIES += libtcmalloc.la
- libtcmalloc_la_SOURCES = $(TCMALLOC_CC) $(TCMALLOC_INCLUDES) \
- $(HEAP_CHECKER_SOURCES)
- libtcmalloc_la_CXXFLAGS = $(PTHREAD_CFLAGS) -DNDEBUG $(AM_CXXFLAGS) \
- $(MAYBE_NO_HEAP_CHECK) $(EMERGENCY_MALLOC_DEFINE)
- libtcmalloc_la_LDFLAGS = $(PTHREAD_CFLAGS) -version-info @TCMALLOC_SO_VERSION@
- libtcmalloc_la_LIBADD = libtcmalloc_internal.la libmaybe_threads.la $(PTHREAD_LIBS)
- # same as above with without -DNDEBUG
- noinst_LTLIBRARIES += libtcmalloc_internal_with_asserts.la
- libtcmalloc_internal_with_asserts_la_SOURCES = $(libtcmalloc_internal_la_SOURCES)
- libtcmalloc_internal_with_asserts_la_CXXFLAGS = $(PTHREAD_CFLAGS) \
- $(AM_CXXFLAGS) $(EMERGENCY_MALLOC_DEFINE) \
- $(MAYBE_NO_HEAP_CHECK)
- libtcmalloc_internal_with_asserts_la_LDFLAGS = $(PTHREAD_CFLAGS)
- libtcmalloc_internal_with_asserts_la_LIBADD = libstacktrace.la $(PTHREAD_LIBS)
- noinst_LTLIBRARIES += libtcmalloc_with_asserts.la
- libtcmalloc_with_asserts_la_SOURCES = $(libtcmalloc_la_SOURCES)
- libtcmalloc_with_asserts_la_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS) \
- $(MAYBE_NO_HEAP_CHECK) $(EMERGENCY_MALLOC_DEFINE)
- libtcmalloc_with_asserts_la_LDFLAGS = $(PTHREAD_CFLAGS)
- libtcmalloc_with_asserts_la_LIBADD = libtcmalloc_internal_with_asserts.la libmaybe_threads.la $(PTHREAD_LIBS)
- LIBTCMALLOC = libtcmalloc.la
- LIBS_TO_WEAKEN += libtcmalloc.la
- ### Unittests
- TESTS += tcmalloc_unittest.sh$(EXEEXT)
- tcmalloc_unittest_sh_SOURCES = src/tests/tcmalloc_unittest.sh
- noinst_SCRIPTS += $(tcmalloc_unittest_sh_SOURCES)
- tcmalloc_unittest.sh$(EXEEXT): $(top_srcdir)/$(tcmalloc_unittest_sh_SOURCES) \
- tcmalloc_unittest
- rm -f $@
- cp -p $(top_srcdir)/$(tcmalloc_unittest_sh_SOURCES) $@
- noinst_PROGRAMS += tcmalloc_unittest
- tcmalloc_unittest_INCLUDES = src/config_for_unittests.h \
- src/gperftools/malloc_extension.h
- tcmalloc_unittest_SOURCES = src/tests/tcmalloc_unittest.cc \
- src/tcmalloc.h \
- src/tests/testutil.h src/tests/testutil.cc \
- $(TCMALLOC_UNITTEST_INCLUDES)
- tcmalloc_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- tcmalloc_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- # We want libtcmalloc last on the link line, but due to a bug in
- # libtool involving convenience libs, they need to come last on the
- # link line in order to get dependency ordering right. This is ok:
- # convenience libraries are .a's, so tcmalloc is still the last .so.
- # We also put pthreads after tcmalloc, because some pthread
- # implementations define their own malloc, and we need to go on the
- # first linkline to make sure our malloc 'wins'.
- tcmalloc_unittest_LDADD = $(LIBTCMALLOC) liblogging.la $(PTHREAD_LIBS)
- TESTS += tcm_asserts_unittest
- tcm_asserts_unittest_INCLUDES = src/config_for_unittests.h \
- src/gperftools/malloc_extension.h
- tcm_asserts_unittest_SOURCES = src/tests/tcmalloc_unittest.cc \
- src/tcmalloc.h \
- src/tests/testutil.h src/tests/testutil.cc \
- $(TCMALLOC_UNITTEST_INCLUDES)
- tcm_asserts_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- tcm_asserts_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- tcm_asserts_unittest_LDADD = libtcmalloc_with_asserts.la liblogging.la $(PTHREAD_LIBS)
- # This makes sure it's safe to link in both tcmalloc and
- # tcmalloc_minimal. (One would never do this on purpose, but perhaps
- # by accident...) When we can compile libprofiler, we also link it in
- # to make sure that works too. NOTE: On OS X, it's *not* safe to
- # link both in (we end up with two copies of every global var, and
- # the code tends to pick one arbitrarily), so don't run the test there.
- # (We define these outside the 'if' because they're reused below.)
- tcmalloc_both_unittest_srcs = src/tests/tcmalloc_unittest.cc \
- src/tests/testutil.h src/tests/testutil.cc \
- $(TCMALLOC_UNITTEST_INCLUDES)
- tcmalloc_both_unittest_cflags = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- tcmalloc_both_unittest_lflags = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- if WITH_CPU_PROFILER
- # We want libtcmalloc last on the link line, but due to a bug in
- # libtool involving convenience libs, they need to come last on the
- # link line in order to get dependency ordering right. This is ok:
- # convenience libraries are .a's, so tcmalloc is still the last .so.
- # We also put pthreads after tcmalloc, because some pthread
- # implementations define their own malloc, and we need to go on the
- # first linkline to make sure our malloc 'wins'.
- tcmalloc_both_unittest_ladd = $(LIBTCMALLOC) $(LIBTCMALLOC_MINIMAL) \
- libprofiler.la liblogging.la $(PTHREAD_LIBS)
- else
- tcmalloc_both_unittest_ladd = $(LIBTCMALLOC) $(LIBTCMALLOC_MINIMAL) \
- liblogging.la $(PTHREAD_LIBS)
- endif !WITH_CPU_PROFILER
- if !OSX
- TESTS += tcmalloc_both_unittest
- tcmalloc_both_unittest_SOURCES = $(tcmalloc_both_unittest_srcs)
- tcmalloc_both_unittest_CXXFLAGS = $(tcmalloc_both_unittest_cflags)
- tcmalloc_both_unittest_LDFLAGS = $(tcmalloc_both_unittest_lflags)
- tcmalloc_both_unittest_LDADD = $(tcmalloc_both_unittest_ladd)
- endif !OSX
- TESTS += tcmalloc_large_unittest
- tcmalloc_large_unittest_SOURCES = src/tests/tcmalloc_large_unittest.cc
- tcmalloc_large_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- tcmalloc_large_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- tcmalloc_large_unittest_LDADD = $(LIBTCMALLOC) $(PTHREAD_LIBS)
- TESTS += tcmalloc_large_heap_fragmentation_unittest
- tcmalloc_large_heap_fragmentation_unittest_SOURCES = src/tests/large_heap_fragmentation_unittest.cc
- tcmalloc_large_heap_fragmentation_unittest_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- tcmalloc_large_heap_fragmentation_unittest_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- tcmalloc_large_heap_fragmentation_unittest_LDADD = $(LIBTCMALLOC) $(PTHREAD_LIBS)
- TESTS += raw_printer_test
- raw_printer_test_SOURCES = src/tests/raw_printer_test.cc
- raw_printer_test_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- raw_printer_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- raw_printer_test_LDADD = $(LIBTCMALLOC) $(PTHREAD_LIBS)
- # sampler_test and sampling_test both require sampling to be turned
- # on, which it's not by default. Use the "standard" value of 2^19.
- TESTS_ENVIRONMENT += TCMALLOC_SAMPLE_PARAMETER=524288
- TESTS += sampler_test
- WINDOWS_PROJECTS += vsprojects/sampler_test/sampler_test.vcxproj
- sampler_test_SOURCES = src/tests/sampler_test.cc \
- src/config_for_unittests.h
- sampler_test_CXXFLAGS = $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- sampler_test_LDFLAGS = $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- sampler_test_LDADD = $(LIBTCMALLOC) $(PTHREAD_LIBS) -lm
- # These unittests often need to run binaries. They're in the current dir
- TESTS_ENVIRONMENT += BINDIR=.
- TESTS_ENVIRONMENT += TMPDIR=/tmp/perftools
- TESTS += sampling_test.sh$(EXEEXT)
- sampling_test_sh_SOURCES = src/tests/sampling_test.sh
- noinst_SCRIPTS += $(sampling_test_sh_SOURCES)
- sampling_test.sh$(EXEEXT): $(top_srcdir)/$(sampling_test_sh_SOURCES) \
- sampling_test
- rm -f $@
- cp -p $(top_srcdir)/$(sampling_test_sh_SOURCES) $@
- # This is the sub-program used by sampling_test.sh
- # The -g is so pprof can get symbol information.
- noinst_PROGRAMS += sampling_test
- SAMPLING_TEST_INCLUDES = src/config_for_unittests.h \
- src/base/logging.h \
- src/gperftools/malloc_extension.h
- sampling_test_SOURCES = src/tests/sampling_test.cc \
- $(SAMPLING_TEST_INCLUDES)
- sampling_test_CXXFLAGS = -g $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- sampling_test_LDFLAGS = -g $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- sampling_test_LDADD = $(LIBTCMALLOC) $(PTHREAD_LIBS)
- endif WITH_HEAP_PROFILER_OR_CHECKER
- if WITH_HEAP_PROFILER
- TESTS += heap-profiler_unittest.sh$(EXEEXT)
- heap_profiler_unittest_sh_SOURCES = src/tests/heap-profiler_unittest.sh
- noinst_SCRIPTS += $(heap_profiler_unittest_sh_SOURCES)
- heap-profiler_unittest.sh$(EXEEXT): $(top_srcdir)/$(heap_profiler_unittest_sh_SOURCES) \
- heap-profiler_unittest
- rm -f $@
- cp -p $(top_srcdir)/$(heap_profiler_unittest_sh_SOURCES) $@
- # These are sub-programs used by heap-profiler_unittest.sh
- noinst_PROGRAMS += heap-profiler_unittest
- HEAP_PROFILER_UNITTEST_INCLUDES = src/config_for_unittests.h \
- src/gperftools/heap-profiler.h
- heap_profiler_unittest_SOURCES = src/tests/heap-profiler_unittest.cc \
- $(HEAP_PROFILER_UNITTEST_INCLUDES)
- heap_profiler_unittest_CXXFLAGS = -g $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- heap_profiler_unittest_LDFLAGS = -g $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- heap_profiler_unittest_LDADD = $(LIBTCMALLOC) $(PTHREAD_LIBS)
- # Tests the compatibility include-headers in google/. Requires a function
- # defined in the heap-profiler, which is why the test lives here.
- TESTS += simple_compat_test
- simple_compat_test_SOURCES = src/tests/simple_compat_test.cc \
- $(googleinclude_HEADERS)
- simple_compat_test_LDFLAGS = $(TCMALLOC_FLAGS)
- simple_compat_test_LDADD = $(LIBTCMALLOC)
- endif WITH_HEAP_PROFILER
- if WITH_HEAP_CHECKER
- TESTS += heap-checker_unittest.sh$(EXEEXT)
- heap_checker_unittest_sh_SOURCES = src/tests/heap-checker_unittest.sh
- noinst_SCRIPTS += $(heap_checker_unittest_sh_SOURCES)
- heap-checker_unittest.sh$(EXEEXT): $(top_srcdir)/$(heap_checker_unittest_sh_SOURCES) \
- heap-checker_unittest
- rm -f $@
- cp -p $(top_srcdir)/$(heap_checker_unittest_sh_SOURCES) $@
- TESTS += heap-checker-death_unittest.sh$(EXEEXT)
- heap_checker_death_unittest_sh_SOURCES = src/tests/heap-checker-death_unittest.sh
- noinst_SCRIPTS += $(top_srcdir)/$(heap_checker_death_unittest_sh_SOURCES)
- heap-checker-death_unittest.sh$(EXEEXT): $(heap_checker_death_unittest_sh_SOURCES) \
- heap-checker_unittest
- rm -f $@
- cp -p $(top_srcdir)/$(heap_checker_death_unittest_sh_SOURCES) $@
- # These are sub-programs used by heap-checker_unittest.sh
- noinst_PROGRAMS += heap-checker_unittest
- HEAP_CHECKER_UNITTEST_INCLUDES = src/config_for_unittests.h \
- src/memory_region_map.h \
- src/base/commandlineflags.h \
- src/base/googleinit.h \
- src/gperftools/heap-checker.h \
- $(LOGGING_INCLUDES)
- heap_checker_unittest_SOURCES = src/tests/heap-checker_unittest.cc \
- $(HEAP_CHECKER_UNITTEST_INCLUDES)
- heap_checker_unittest_CXXFLAGS = -g $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- heap_checker_unittest_LDFLAGS = -g $(PTHREAD_CFLAGS) $(TCMALLOC_FLAGS)
- # We want libtcmalloc last on the link line, but due to a bug in
- # libtool involving convenience libs, they need to come last on the
- # link line in order to get dependency ordering right. This is ok:
- # convenience libraries are .a's, so tcmalloc is still the last .so.
- # We also put pthreads after tcmalloc, because some pthread
- # implementations define their own malloc, and we need to go on the
- # first linkline to make sure our malloc 'wins'.
- heap_checker_unittest_LDADD = $(LIBTCMALLOC) liblogging.la $(PTHREAD_LIBS)
- endif WITH_HEAP_CHECKER
- ### Documentation (above and beyond tcmalloc_minimal documentation)
- if WITH_HEAP_PROFILER
- dist_doc_DATA += docs/heapprofile.html docs/heap-example1.png
- endif WITH_HEAP_PROFILER
- if WITH_HEAP_CHECKER
- dist_doc_DATA += docs/heap_checker.html
- endif WITH_HEAP_CHECKER
- ### ------- tcmalloc with debugallocation
- if WITH_DEBUGALLOC
- if WITH_HEAP_PROFILER_OR_CHECKER
- lib_LTLIBRARIES += libtcmalloc_debug.la
- libtcmalloc_debug_la_SOURCES = src/debugallocation.cc $(HEAP_CHECKER_SOURCES) \
- $(TCMALLOC_INCLUDES)
- libtcmalloc_debug_la_CXXFLAGS = $(libtcmalloc_la_CXXFLAGS) \
- -DTCMALLOC_FOR_DEBUGALLOCATION
- libtcmalloc_debug_la_LDFLAGS = $(libtcmalloc_la_LDFLAGS) \
- -version-info @TCMALLOC_SO_VERSION@
- libtcmalloc_debug_la_LIBADD = $(libtcmalloc_la_LIBADD)
- LIBS_TO_WEAKEN += libtcmalloc_debug.la
- ### Unittests
- TESTS += tcmalloc_debug_unittest
- tcmalloc_debug_unittest_SOURCES = $(tcmalloc_unittest_SOURCES)
- tcmalloc_debug_unittest_CXXFLAGS = $(tcmalloc_unittest_CXXFLAGS) \
- -DDEBUGALLOCATION
- tcmalloc_debug_unittest_LDFLAGS = $(tcmalloc_unittest_LDFLAGS)
- tcmalloc_debug_unittest_LDADD = libtcmalloc_debug.la $(PTHREAD_LIBS)
- TESTS += sampler_debug_test
- sampler_debug_test_SOURCES = $(sampler_test_SOURCES)
- sampler_debug_test_CXXFLAGS = $(samples_test_CXXFLAGS)
- sampler_debug_test_LDFLAGS = $(sampler_test_LDFLAGS)
- sampler_debug_test_LDADD = libtcmalloc_debug.la $(PTHREAD_LIBS) -lm
- TESTS += sampling_debug_test.sh$(EXEEXT)
- sampling_debug_test_sh_SOURCES = src/tests/sampling_test.sh
- sampling_debug_test.sh$(EXEEXT): $(top_srcdir)/$(sampling_test_sh_SOURCES) \
- sampling_debug_test
- rm -f $@
- cp -p $(top_srcdir)/$(sampling_test_sh_SOURCES) $@
- # This is the sub-program using by sampling_debug_test.sh
- # The -g is so pprof can get symbol information.
- noinst_PROGRAMS += sampling_debug_test
- sampling_debug_test_SOURCES = $(sampling_test_SOURCES)
- sampling_debug_test_CXXFLAGS = $(sampling_test_CXXFLAGS)
- sampling_debug_test_LDFLAGS = $(sampling_test_LDFLAGS)
- sampling_debug_test_LDADD = libtcmalloc_debug.la $(PTHREAD_LIBS)
- endif WITH_HEAP_PROFILER_OR_CHECKER
- if WITH_HEAP_PROFILER
- TESTS += heap-profiler_debug_unittest.sh$(EXEEXT)
- heap_profiler_debug_unittest_sh_SOURCES = src/tests/heap-profiler_unittest.sh
- heap-profiler_debug_unittest.sh$(EXEEXT): $(top_srcdir)/$(heap_profiler_unittest_sh_SOURCES) \
- heap-profiler_debug_unittest
- rm -f $@
- cp -p $(top_srcdir)/$(heap_profiler_unittest_sh_SOURCES) $@
- # These are sub-programs used by heap-profiler_debug_unittest.sh
- noinst_PROGRAMS += heap-profiler_debug_unittest
- heap_profiler_debug_unittest_SOURCES = $(heap_profiler_unittest_SOURCES)
- heap_profiler_debug_unittest_CXXFLAGS = $(heap_profiler_unittest_CXXFLAGS)
- heap_profiler_debug_unittest_LDFLAGS = $(heap_profiler_unittest_LDFLAGS)
- heap_profiler_debug_unittest_LDADD = libtcmalloc_debug.la $(PTHREAD_LIBS)
- endif WITH_HEAP_PROFILER
- if WITH_HEAP_CHECKER
- TESTS += heap-checker_debug_unittest.sh$(EXEEXT)
- heap_checker_debug_unittest_sh_SOURCES = src/tests/heap-checker_unittest.sh
- heap-checker_debug_unittest.sh$(EXEEXT): $(top_srcdir)/$(heap_checker_unittest_sh_SOURCES) \
- heap-checker_debug_unittest
- rm -f $@
- cp -p $(top_srcdir)/$(heap_checker_unittest_sh_SOURCES) $@
- # These are sub-programs used by heap-checker_debug_unittest.sh
- noinst_PROGRAMS += heap-checker_debug_unittest
- heap_checker_debug_unittest_SOURCES = $(heap_checker_unittest_SOURCES)
- heap_checker_debug_unittest_CXXFLAGS = $(heap_checker_unittest_CXXFLAGS)
- heap_checker_debug_unittest_LDFLAGS = $(heap_checker_unittest_LDFLAGS)
- # We want libtcmalloc last on the link line, but due to a bug in
- # libtool involving convenience libs, they need to come last on the
- # link line in order to get dependency ordering right. This is ok:
- # convenience libraries are .a's, so tcmalloc is still the last .so.
- heap_checker_debug_unittest_LDADD = libtcmalloc_debug.la liblogging.la \
- $(PTHREAD_LIBS)
- endif WITH_HEAP_CHECKER
- endif WITH_DEBUGALLOC
- ### ------- CPU profiler
- if WITH_CPU_PROFILER
- ### The header files we use. We divide into categories based on directory
- S_CPU_PROFILER_INCLUDES = src/profiledata.h \
- src/profile-handler.h \
- src/getpc.h \
- src/base/basictypes.h \
- src/base/commandlineflags.h \
- src/base/googleinit.h \
- src/base/logging.h \
- src/base/simple_mutex.h \
- src/base/sysinfo.h \
- $(SPINLOCK_INCLUDES) \
- $(LOGGING_INCLUDES)
- SG_CPU_PROFILER_INCLUDES = src/gperftools/profiler.h
- CPU_PROFILER_INCLUDES = $(S_CPU_PROFILER_INCLUDES) $(SG_CPU_PROFILER_INCLUDES) \
- $(SG_STACKTRACE_INCLUDES)
- perftoolsinclude_HEADERS += $(SG_CPU_PROFILER_INCLUDES)
- ### Making the library
- lib_LTLIBRARIES += libprofiler.la
- libprofiler_la_SOURCES = src/profiler.cc \
- src/profile-handler.cc \
- src/profiledata.cc \
- $(CPU_PROFILER_INCLUDES)
- libprofiler_la_LIBADD = libstacktrace.la libmaybe_threads.la libfake_stacktrace_scope.la
- # We have to include ProfileData for profiledata_unittest
- CPU_PROFILER_SYMBOLS = '(ProfilerStart|ProfilerStartWithOptions|ProfilerStop|ProfilerFlush|ProfilerEnable|ProfilerDisable|ProfilingIsEnabledForAllThreads|ProfilerRegisterThread|ProfilerGetCurrentState|ProfilerState|ProfileData|ProfileHandler|ProfilerGetStackTrace)'
- libprofiler_la_LDFLAGS = -export-symbols-regex $(CPU_PROFILER_SYMBOLS) \
- -version-info @PROFILER_SO_VERSION@
- # See discussion above (under LIBTCMALLOC_MINIMAL) for why we do this.
- # Basically it's to work around systems where --rpath doesn't work right.
- LIBPROFILER = libstacktrace.la libprofiler.la
- ### Unittests
- TESTS += getpc_test
- #WINDOWS_PROJECTS += vsprojects/getpc_test/getpc_test.vcxproj
- getpc_test_SOURCES = src/tests/getpc_test.cc src/getpc.h
- TESTS += profiledata_unittest
- #WINDOWS_PROJECTS += vsprojects/profiledata_unittest/profiledata_unittest.vcxproj
- profiledata_unittest_SOURCES = src/tests/profiledata_unittest.cc \
- src/profiledata.h \
- src/base/commandlineflags.h \
- src/base/logging.h \
- src/base/basictypes.h
- profiledata_unittest_LDADD = $(LIBPROFILER)
- TESTS += profile_handler_unittest
- profile_handler_unittest_SOURCES = src/tests/profile-handler_unittest.cc \
- src/profile-handler.h
- profile_handler_unittest_CXXFLAGS = $(PTHREAD_CFLAGS)
- profile_handler_unittest_LDFLAGS = $(PTHREAD_CFLAGS)
- profile_handler_unittest_LDADD = $(LIBPROFILER) $(PTHREAD_LIBS)
- TESTS += profiler_unittest.sh$(EXEEXT)
- profiler_unittest_sh_SOURCES = src/tests/profiler_unittest.sh
- noinst_SCRIPTS += $(profiler_unittest_sh_SOURCES)
- profiler_unittest.sh$(EXEEXT): $(top_srcdir)/$(profiler_unittest_sh_SOURCES) \
- profiler1_unittest profiler2_unittest \
- profiler3_unittest profiler4_unittest
- rm -f $@
- cp -p $(top_srcdir)/$(profiler_unittest_sh_SOURCES) $@
- # These are sub-programs used by profiler_unittest.sh
- noinst_PROGRAMS += profiler1_unittest profiler2_unittest profiler3_unittest \
- profiler4_unittest
- PROFILER_UNITTEST_INCLUDES = src/config_for_unittests.h \
- src/gperftools/profiler.h
- PROFILER_UNITTEST_SRCS = src/tests/profiler_unittest.cc \
- src/tests/testutil.h src/tests/testutil.cc \
- $(PROFILER_UNITTEST_INCLUDES)
- profiler1_unittest_SOURCES = $(PROFILER_UNITTEST_SRCS)
- profiler1_unittest_CXXFLAGS = -g -DNO_THREADS $(AM_CXXFLAGS)
- profiler1_unittest_LDADD = $(LIBPROFILER)
- profiler2_unittest_SOURCES = $(PROFILER_UNITTEST_SRCS)
- profiler2_unittest_CXXFLAGS = -g -DNO_THREADS $(AM_CXXFLAGS)
- profiler2_unittest_LDADD = -lstacktrace -lprofiler
- # We depend on -lprofiler but haven't yet said how to build it. Do so now.
- profiler2_unittest_DEPENDENCIES = $(LIBPROFILER)
- profiler3_unittest_SOURCES = $(PROFILER_UNITTEST_SRCS)
- profiler3_unittest_CXXFLAGS = -g $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- profiler3_unittest_LDFLAGS = $(PTHREAD_CFLAGS)
- profiler3_unittest_LDADD = $(LIBPROFILER) $(PTHREAD_LIBS)
- profiler4_unittest_SOURCES = $(PROFILER_UNITTEST_SRCS)
- profiler4_unittest_CXXFLAGS = -g $(PTHREAD_CFLAGS) $(AM_CXXFLAGS)
- profiler4_unittest_LDFLAGS = $(PTHREAD_CFLAGS)
- profiler4_unittest_LDADD = -lstacktrace -lprofiler $(PTHREAD_LIBS)
- # We depend on -lprofiler but haven't yet said how to build it. Do so now.
- profiler4_unittest_DEPENDENCIES = $(LIBPROFILER)
- ### Documentation
- dist_doc_DATA += docs/cpuprofile.html \
- docs/cpuprofile-fileformat.html \
- docs/pprof-test-big.gif \
- docs/pprof-test.gif \
- docs/pprof-vsnprintf-big.gif \
- docs/pprof-vsnprintf.gif
- endif WITH_CPU_PROFILER
- ### ------- CPU profiler and heap checker, in one!
- # Ideally, folks who wanted to use both tcmalloc and libprofiler,
- # could just link them both into their application. But while this
- # works fine for .so files, it does not for .a files. The easiest way
- # around this -- and I've tried a bunch of the hard ways -- is to just
- # to create another set of libraries that has both functionality in it.
- if WITH_HEAP_PROFILER_OR_CHECKER
- if WITH_CPU_PROFILER
- lib_LTLIBRARIES += libtcmalloc_and_profiler.la
- libtcmalloc_and_profiler_la_SOURCES = $(libtcmalloc_la_SOURCES) $(libprofiler_la_SOURCES)
- libtcmalloc_and_profiler_la_CXXFLAGS = $(libtcmalloc_la_CXXFLAGS) $(libprofiler_la_CXXFLAGS)
- # Since this library is meant to be used as a .a, I don't worry as much
- # about .so versioning. I just give the libtcmalloc version number.
- # TODO(csilvers): use -export-symbols-regex?
- libtcmalloc_and_profiler_la_LDFLAGS = $(PTHREAD_CFLAGS) \
- -version-info @TCMALLOC_AND_PROFILER_SO_VERSION@
- # We don't include libprofiler_la_LIBADD here because all it adds is
- # libstacktrace.la, which we already get via libtcmalloc. Trying to
- # specify it twice causes link-time duplicate-definition errors. :-(
- libtcmalloc_and_profiler_la_LIBADD = $(libtcmalloc_la_LIBADD)
- TESTS += tcmalloc_and_profiler_unittest
- tcmalloc_and_profiler_unittest_SOURCES = $(tcmalloc_both_unittest_srcs)
- tcmalloc_and_profiler_unittest_CXXFLAGS = $(tcmalloc_both_unittest_cflags)
- tcmalloc_and_profiler_unittest_LDFLAGS = $(tcmalloc_both_unittest_lflags)
- tcmalloc_and_profiler_unittest_LDADD = libtcmalloc_and_profiler.la
- LIBS_TO_WEAKEN += libtcmalloc_and_profiler.la
- endif WITH_CPU_PROFILER
- endif WITH_HEAP_PROFILER_OR_CHECKER
- ## ^^^^ END OF RULES TO MAKE YOUR LIBRARIES, BINARIES, AND UNITTESTS
- # Do the weakening on some exported libtcmalloc symbols.
- install-exec-local: all-local
- all-local: $(LIBS_TO_WEAKEN)
- for la in $(LIBS_TO_WEAKEN); do lib=".libs/`basename $$la .la`.a"; [ ! -f "$$lib" ] || $(WEAKEN) "$$lib"; done
- # This should always include $(TESTS), but may also include other
- # binaries that you compile but don't want automatically installed.
- # We'll add to this later, on a library-by-library basis
- noinst_PROGRAMS += $(TESTS)
- rpm: dist-gzip packages/rpm.sh packages/rpm/rpm.spec
- @cd packages && ./rpm.sh ${PACKAGE} ${VERSION}
- deb: dist-gzip packages/deb.sh packages/deb/*
- @cd packages && ./deb.sh ${PACKAGE} ${VERSION}
- # http://linux.die.net/man/1/pkg-config, http://pkg-config.freedesktop.org/wiki
- pkgconfigdir = $(libdir)/pkgconfig
- pkgconfig_DATA = libtcmalloc.pc libtcmalloc_minimal.pc \
- libtcmalloc_debug.pc libtcmalloc_minimal_debug.pc \
- libprofiler.pc
- CLEANFILES = $(pkgconfig_DATA)
- # I get the description and URL lines from the rpm spec. I use sed to
- # try to rewrite exec_prefix, libdir, and includedir in terms of
- # prefix, if possible.
- libtcmalloc.pc: Makefile packages/rpm/rpm.spec
- echo 'prefix=$(prefix)' > "$@".tmp
- echo 'exec_prefix='`echo '$(exec_prefix)' | sed 's@^$(prefix)@$${prefix}@'` >> "$@".tmp
- echo 'libdir='`echo '$(libdir)' | sed 's@^$(exec_prefix)@$${exec_prefix}@'` >> "$@".tmp
- echo 'includedir='`echo '$(includedir)' | sed 's@^$(prefix)@$${prefix}@'` >> "$@".tmp
- echo '' >> "$@".tmp
- echo 'Name: $(PACKAGE)' >> "$@".tmp
- echo 'Version: $(VERSION)' >> "$@".tmp
- -grep '^Summary:' $(top_srcdir)/packages/rpm/rpm.spec | sed s/^Summary:/Description:/ | head -n1 >> "$@".tmp
- -grep '^URL: ' $(top_srcdir)/packages/rpm/rpm.spec >> "$@".tmp
- echo 'Requires:' >> "$@".tmp
- echo 'Libs: -L$${libdir} -ltcmalloc' >> "$@".tmp
- echo 'Libs.private: $(PTHREAD_CFLAGS) $(PTHREAD_LIBS)' >> "$@".tmp
- echo 'Cflags: -I$${includedir}' >> "$@".tmp
- mv -f "$@".tmp "$@"
- # The other versions are mostly the same.
- libtcmalloc_minimal.pc: libtcmalloc.pc
- cat libtcmalloc.pc | sed s/-ltcmalloc/-ltcmalloc_minimal/ > "$@"
- libtcmalloc_debug.pc: libtcmalloc.pc
- cat libtcmalloc.pc | sed s/-ltcmalloc/-ltcmalloc_debug/ > "$@"
- libtcmalloc_minimal_debug.pc: libtcmalloc.pc
- cat libtcmalloc.pc | sed s/-ltcmalloc/-ltcmalloc_minimal_debug/ > "$@"
- libprofiler.pc: libtcmalloc.pc
- cat libtcmalloc.pc | sed s/-ltcmalloc/-lprofiler/ > "$@"
- libtool: $(LIBTOOL_DEPS)
- $(SHELL) ./config.status --recheck
- @GENERATE_CHANGELOG_RULES@
- # Windows wants write permission to .vcxproj files and maybe even sln files.
- dist-hook: dist-ChangeLog
- test -e "$(distdir)/vsprojects" \
- && chmod -R u+w $(distdir)/*.sln $(distdir)/vsprojects/
- EXTRA_DIST = packages/rpm.sh packages/rpm/rpm.spec packages/deb.sh packages/deb \
- $(SCRIPTS) libtool \
- src/windows/get_mangled_names.cc src/windows/override_functions.cc \
- src/windows/config.h src/windows/gperftools/tcmalloc.h \
- docs/pprof.see_also src/windows/TODO \
- $(WINDOWS_PROJECTS) \
- src/solaris/libstdc++.la
|