Commit Graph

443 Commits

Author SHA1 Message Date
Brian Silverman
126d4582c1 Call function pointers with the right type
I think it's undefined behavior, but it's definitely weird. ubsan
complains too.
2016-03-05 20:00:39 -05:00
Brian Silverman
e0fa28ef7d Don't shift a type by more than its width
It's undefined behavior, so ubsan complains.
2016-03-01 17:59:39 -05:00
Brian Silverman
a1c764d263 Initialize counters in test 2016-03-01 17:59:39 -05:00
Brian Silverman
22123a37c2 Don't overflow a signed integer
It's undefined behavior and ubsan catches it.
2016-03-01 17:59:08 -05:00
Aliaksey Kandratsenka
66e1e94f38 added minimal "header section" to README 2016-02-29 20:09:39 -08:00
Aliaksey Kandratsenka
2804b7cfee bumped version to 2.5rc 2016-02-21 23:09:15 -08:00
Aliaksey Kandratsenka
f47fefbfc1 updated NEWS for 2.5rc 2016-02-21 23:09:15 -08:00
Aliaksey Kandratsenka
cef6036174 alias same malloc/free variants to their canonical versions
This is similar to what gcc 5 does anyways, except gcc 5 is placing
jumps which adds a bit of overhead.

Instead of letting gcc do it, we alias using ELF symbol aliasing. All
free variants (tc_delete{,array}_{,nothrow}) are aliased to
tc_free. There are 3 malloc variants that differ by oom
handling. tc_newarray is aliased to tc_new. And tc_newarray_nothrow is
aliased to tc_new_nothrow.

This aliasing only happens in non-debug malloc, since debug malloc does
distinguish between different variants since it needs checking for
mismatch.
2016-02-21 23:09:15 -08:00
Aliaksey Kandratsenka
ea8d242061 Re-enable MultipleIdleNonIdlePhases test
Which was accidentally removed as part of MarkThreadTemporarilyIdle
support.
2016-02-21 20:16:37 -08:00
Aliaksey Kandratsenka
c9962f698b added maybe_emergency_malloc.h to Makefile.am
Because without this reference it isn't packaged by make dist.
2016-02-21 20:07:37 -08:00
Aliaksey Kandratsenka
7dd4af6536 don't round up sizes for large allocation when sampling
This closes #723.

Since rounding up prior to sampling is introducing possibility of
arithmetic overflow, we're just not doing it.

It introduces some error (up to 4k), but since we're dealing with at
least 256k allocations, we're fine.
2016-02-21 19:26:37 -08:00
Aliaksey Kandratsenka
4f3410e759 enable emergency malloc by default on arm when using libunwind
Because by default libunwind on arm does fopen which mallocs which will
deadlock unless we enable emergency malloc.
2016-02-21 13:57:27 -08:00
Aliaksey Kandratsenka
7f12051dbe implemented emergency malloc
Emergency malloc is enabled for cases when backtrace capturing needs to
call malloc. In this case, we enable emergency malloc just prior to
calling such code and disable it after it is done.
2016-02-21 10:53:45 -08:00
Aliaksey Kandratsenka
3ee2360250 replaced invalid uses of __THROW
We're now using it only when overriding glibc functions (such as malloc
or mmap). In other cases (most importantly in public tcmalloc.h header)
we're doing our own throw() to avoid possible breakage on future glibc
changes.
2016-02-20 22:13:07 -08:00
Aliaksey Kandratsenka
013b82abcf unbreak <malloc.h> inclusion in gperftools/tcmalloc.h
We have shipped header which checked HAVE_XXX defines which we only
defined in project-local config.h. So it could never work correctly.

We're now doing #include <malloc.h> just like tc_mallinfo on constant
which we detect at configure time and write into header that we install.
2016-02-20 22:07:48 -08:00
Aliaksey Kandratsenka
19903e6f15 drop detection of sys/malloc.h and malloc/malloc.h
Which we don't really need.
2016-02-20 22:07:48 -08:00
Aliaksey Kandratsenka
cdff090ebd Fix several harmless clang warnings 2016-02-20 22:07:26 -08:00
Aliaksey Kandratsenka
9095ed0840 implemented stacktrace capturing via libgcc's C++ ABI function
Particularly _Unwind_Backtrace which seems to be gcc extension.

This is what glibc's backtrace is commonly is using.

Using _Unwind_Backtrace directly is better than glibc's backtrace, since
it doesn't call into dlopen. While glibc does dlopen when it is built as
shared library apparently to avoid link-time dependency on libgcc_s.so
2016-02-20 20:34:50 -08:00
Aliaksey Kandratsenka
728cbe1021 force profiler_unittest to do 'real' work
'XOR loop' in profiler unittest wasn't 100% effective because it allowed
compiler to avoid loading and storing to memory.

After marking result variable as volatile, we're now forcing compiler to
read and write memory, slowing this loops down sufficiently. And
profiler_unittest is now passing more consistently.

Closes #628
2016-02-20 13:21:47 -08:00
Aliaksey Kandratsenka
fff6b4fb88 Extend low-level allocator to support custom pages allocator 2016-02-06 19:14:23 -08:00
Aliaksey Kandratsenka
32d9926795 added malloc_bench_shared_full 2016-02-06 19:14:23 -08:00
Aliaksey Kandratsenka
00d8fa1ef8 always use real throw() on operators new/delete
Since non-glibc-s have no __THROW and lack of throw() on operators gives
us warning.
2016-02-06 19:13:07 -08:00
Aliaksey Kandratsenka
08e034ad59 Detect working ifunc before enabling dynamic sized delete support
Particularly, on arm-linux and x86-64-debian-kfreebsd compilation fails
due to lack of support for ifunc. So it is necessary to test at
configure time whether ifunc is supported.
2016-02-06 16:21:53 -08:00
Aliaksey Kandratsenka
a788f354a0 include unistd.h for getpid in thread_lister.c
This fixes warning produced on arm-linux.
2016-02-06 16:21:53 -08:00
Bryan Chan
644a6bdbdb Add support for Linux s390x
This resolves gperftools/gperftools#761.
2016-02-04 20:15:26 -05:00
Bryan Chan
bab7753aad Fix typo in heap-checker-death_unittest.sh 2016-02-04 18:34:43 -05:00
Simon Que
17182e1d3c Fix include of malloc_hook_c.h in malloc_hook.h
malloc_hook.h includes malloc_hook_c.h as <gperftools/malloc_hook_c.h>.
This requires the compiler to have designated src/gperftools as a
standard include directory (-I), which may not always be the case.

Instead, include it as "malloc_hook_c.h", which will search in the same
directory first. This will always work, regardless of whether it was
designated a standard include directory.
2016-01-29 18:17:16 -08:00
Andrew Morrow
c69721b2b2 Add support for obtaining cache size of the current thread and softer idling 2016-01-26 19:44:16 -08:00
Brian Silverman
5ce42e535d Don't always arm the profiling timer.
It causes a noticeable performance hit and can sometimes confuse GDB.

Tested with CPUPROFILE_PER_THREAD_TIMERS=1.

Based on an old version by mnissler@google.com.
2016-01-26 18:31:42 -08:00
Duncan Sands
7f801ea091 Make sure the alias is not removed by link-time optimization when it can prove
that it isn't used by the program, as it might still be needed to override the
corresponding symbol in shared libraries (or inline assembler for that matter).
For example, suppose the program uses malloc and free but not calloc and is
statically linked against tcmalloc (built with -flto) and LTO is done.  Then
before this patch the calloc alias would be deleted by LTO due to not being
used, but the malloc/free aliases would be kept because they are used by the
program.  Suppose the program is dynamically linked with a shared library that
allocates memory using calloc and later frees it by calling free.  Then calloc
will use the libc memory allocator, because the calloc alias was deleted, but
free will call into tcmalloc, resulting in a crash.
2016-01-24 19:49:52 -08:00
Aliaksey Kandratsenka
6b3e6ef5e0 don't retain compatibility with old docdir behavior
Since it is not really needed. And since we don't care about too ancient
autoconfs.
2016-01-24 19:45:16 -08:00
Chris Mayo
ccffcbd9e9 support use of configure --docdir argument
Value of docdir was being overridden in Makefile.

Retain compatibility with old Autoconf versions that do not provide
docdir.
2015-12-27 18:55:05 +00:00
Aliaksey Kandratsenka
050f2d28be use alias attribute only for elf platforms
It was reported that clang on OSX doesn't support alias attribute. Most
likely because of executable format limitations.

New code limits use of alias to gcc-compatible compilers on elf
platforms (various gnu and *bsd systems). Elf format is known to support
aliases.
2015-12-12 18:27:56 -08:00
cyshi
07b0b21ddd fix compilation error in spinlock 2015-12-02 14:47:15 +08:00
gshirishfree
e14450366a Added better description for GetStats API 2015-11-23 11:34:13 -08:00
Aliaksey Kandratsenka
64892ae730 lower default transfer batch size down to 512
Some workloads get much slower with too large batch size.

This closes bug #678.

binary_trees benchmark benefits from larger batch size. And I found that
512 is not much slower than huge value that we had.
2015-11-21 19:22:49 -08:00
Aliaksey Kandratsenka
6fdfc5a7f4 implemented enabling sized-delete support at runtime
Under gcc 4.5 or greater we're using ifunc function attribute to resolve
sized delete operator to either plain delete implementation (default) or
to sized delete (if enabled via environment variable
TCMALLOC_ENABLE_SIZED_DELETE).
2015-11-21 19:03:03 -08:00
Aliaksey Kandratsenka
c2a79d063c use x86 pause in spin loop
This saves power and improves performance, particulary on SMT.
2015-11-21 18:17:24 -08:00
Aliaksey Kandratsenka
0fb6dd8aa3 added binary_trees benchmark 2015-11-21 18:17:21 -08:00
Aliaksey Kandratsenka
a8852489e5 drop unsupported allocation sampling code in tcmalloc_minimal 2015-11-21 17:43:42 -08:00
Aliaksey Kandratsenka
a9db0ae516 implemented (disabled by default) sized delete support
gcc 5 and clang++-3.7 support sized deallocation from C++14. We are
taking advantage of that by defining sized versions of operator delete.

This is off by default so that if some existing programs that define own
global operator delete without sized variant are not broken by
tcmalloc's sized delete operator.

There is also risk of breaking exiting code that deletes objects using
wrong class (i.e. base class) without having virtual destructors.
2015-11-21 17:43:42 -08:00
Aliaksey Kandratsenka
88686972b9 pass -fsized-deallocation to gcc 5
Otherwise it gives warning for declaration of sized delete operator.
2015-11-21 17:43:42 -08:00
Aliaksey Kandratsenka
0a18fab3af implemented sized free support via tc_free_sized 2015-11-21 17:43:42 -08:00
Aliaksey Kandratsenka
464688ab6d speedup free code path by dropping "fast path allowed check" 2015-11-21 17:43:42 -08:00
Aliaksey Kandratsenka
10f7e20716 added SizeMap::MaybeSizeClass
Because it allows us to first check for smaller sizes, which is most
likely.
2015-11-21 17:43:42 -08:00
Aliaksey Kandratsenka
436e1dea43 slightly faster GetCacheIfPresent 2015-11-21 17:43:42 -08:00
Aliaksey Kandratsenka
04df911915 tell compiler that non-empty hooks are unlikely 2015-11-21 17:43:42 -08:00
Aliaksey Kandratsenka
8cc75acd1f correctly test for -Wno-unused-result support
gcc is only giving warning for unknown -Wno-XXX flags so test never
fails on gcc even if -Wno-XXX is not supported. By using
-Wunused-result we're able to test if gcc actually supports it.

This fixes issue #703.
2015-11-21 17:43:42 -08:00
Aliaksey Kandratsenka
7753d8239b fixed clang warning about shifting negative values 2015-11-21 17:43:42 -08:00
Jens Rosenboom
ae09ebb383 Fix tmpdir usage in heap-profiler_unittest.sh
Using a single fixed directory would break when tests were being run in
parallel with "make -jN".

Also, the cleanup at the end of the test didn't work because it referred
to the wrong variable.
2015-11-21 17:37:49 -08:00