llvm-project/compiler-rt/lib/scudo/standalone
Kostya Kortchinsky bebdab63e8 [scudo][standalone] Correct releaseToOS behavior
Summary:
There was an issue in `releaseToOSMaybe`: one of the criteria to
decide if we should proceed with the release was wrong. Namely:

```
const uptr N = Sci->Stats.PoppedBlocks - Sci->Stats.PushedBlocks;
if (N * BlockSize < PageSize)
  return; // No chance to release anything.
```

I meant to check if the amount of bytes in the free list was lower
than a page, but this actually checks if the amount of **in use** bytes
was lower than a page.

The correct code is:

```
const uptr BytesInFreeList =
  Region->AllocatedUser -
  (Region->Stats.PoppedBlocks - Region->Stats.PushedBlocks) * BlockSize;
if (BytesInFreeList < PageSize)
  return 0; // No chance to release anything.
```

Consequences of the bug:
- if a class size has less than a page worth of in-use bytes (allocated
  or in a cache), reclaiming would not occur, whatever the amount of
  blocks in the free list; in real world scenarios this is unlikely to
  happen and be impactful;
- if a class size had less than a page worth of free bytes (and enough
  in-use bytes, etc), then reclaiming would be attempted, with likely
  no result. This means the reclaiming was overzealous at times.

I didn't have a good way to test for this, so I changed the prototype
of the function to return the number of bytes released, allowing to
get the information needed. The test added fails with the initial
criteria.

Another issue is that `ReleaseToOsInterval` can actually be 0, meaning
we always try to release (side note: it's terrible for performances).
so change a `> 0` check to `>= 0`.

Additionally, decrease the `CanRelease` threshold to `PageSize / 32`.
I still have to make that configurable but I will do it at another time.

Finally, rename some variables in `printStats`: I feel like "available"
was too ambiguous, so change it to "total".

Reviewers: morehouse, hctim, eugenis, vitalybuka, cferris

Reviewed By: morehouse

Subscribers: delcypher, #sanitizers, llvm-commits

Tags: #llvm, #sanitizers

Differential Revision: https://reviews.llvm.org/D68471

llvm-svn: 373930
2019-10-07 17:37:39 +00:00
..
tests [scudo][standalone] Correct releaseToOS behavior 2019-10-07 17:37:39 +00:00
CMakeLists.txt compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
allocator_config.h [scudo][standalone] Android related improvements 2019-09-11 14:48:41 +00:00
atomic_helpers.h [scudo][standalone] Merge Spin & Blocking mutex into a Hybrid one 2019-07-11 15:32:26 +00:00
bytemap.h [scudo][standalone] Merge Spin & Blocking mutex into a Hybrid one 2019-07-11 15:32:26 +00:00
checksum.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
checksum.h [scudo][standalone] Introduce the chunk header 2019-05-08 21:54:02 +00:00
chunk.h compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
combined.h [scudo][standalone] Android related improvements 2019-09-11 14:48:41 +00:00
common.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
common.h [scudo][standalone] Merge Spin & Blocking mutex into a Hybrid one 2019-07-11 15:32:26 +00:00
crc32_hw.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
flags.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
flags.h [scudo][standalone] Add flags & related parsers 2019-04-09 14:57:25 +00:00
flags.inc [scudo][standalone] Add flags & related parsers 2019-04-09 14:57:25 +00:00
flags_parser.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
flags_parser.h [scudo][standalone] Introduce the C & C++ wrappers [fixed] 2019-06-27 14:23:26 +00:00
fuchsia.cpp [scudo][standalone] Minor corrections 2019-08-12 15:35:09 +00:00
fuchsia.h [scudo][standalone] Introduce the Secondary allocator 2019-04-24 14:20:49 +00:00
interface.h [scudo][standalone] Add flags & related parsers 2019-04-09 14:57:25 +00:00
internal_defs.h [scudo][standalone] Minor corrections 2019-08-12 15:35:09 +00:00
linux.cpp [scudo][standalone] Minor corrections 2019-08-12 15:35:09 +00:00
linux.h [scudo][standalone] Introduce the Secondary allocator 2019-04-24 14:20:49 +00:00
list.h [scudo][standalone] Minor corrections 2019-08-12 15:35:09 +00:00
local_cache.h [scudo][standalone] Add more stats to mallinfo 2019-08-14 16:04:01 +00:00
mutex.h [scudo][standalone] Add more stats to mallinfo 2019-08-14 16:04:01 +00:00
platform.h
primary32.h [scudo][standalone] Correct releaseToOS behavior 2019-10-07 17:37:39 +00:00
primary64.h [scudo][standalone] Correct releaseToOS behavior 2019-10-07 17:37:39 +00:00
quarantine.h [scudo][standalone] Minor corrections 2019-08-12 15:35:09 +00:00
release.h [scudo][standalone] Add the memory reclaiming mechanism 2019-04-30 14:56:18 +00:00
report.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
report.h [scudo][standalone] Add error reports 2019-03-20 14:31:23 +00:00
secondary.cpp [scudo][standalone] Minor corrections 2019-08-12 15:35:09 +00:00
secondary.h [scudo][standalone] Optimization pass 2019-07-24 16:36:01 +00:00
size_class_map.h [scudo][standalone] Android related improvements 2019-09-11 14:48:41 +00:00
stats.h [scudo][standalone] Add more stats to mallinfo 2019-08-14 16:04:01 +00:00
string_utils.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
string_utils.h [scudo][standalone] Add string utility functions 2019-03-19 14:47:05 +00:00
tsd.h [scudo][standalone] Merge Spin & Blocking mutex into a Hybrid one 2019-07-11 15:32:26 +00:00
tsd_exclusive.h [scudo][standalone] Optimization pass 2019-07-24 16:36:01 +00:00
tsd_shared.h [scudo][standalone] Optimization pass 2019-07-24 16:36:01 +00:00
vector.h [scudo][standalone] Add a standalone vector class 2019-02-27 16:30:05 +00:00
wrappers_c.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
wrappers_c.h [scudo][standalone] Introduce the C & C++ wrappers [fixed] 2019-06-27 14:23:26 +00:00
wrappers_c.inc [scudo][standalone] Make malloc_info return a minimal XML 2019-10-04 15:46:34 +00:00
wrappers_c_bionic.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00
wrappers_c_checks.h [scudo][standalone] Introduce the C & C++ wrappers [fixed] 2019-06-27 14:23:26 +00:00
wrappers_cpp.cpp compiler-rt: Rename .cc file in lib/scudo/standalone to .cpp 2019-08-01 14:36:38 +00:00