Not using aligned_alloc with gcc4 + asan

Summary:
GCC < 5 + ASAN does not instrument aligned_alloc, which can make ASAN
report false-positive with "free on address which was not malloc" error.
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=61693

Also suppress leak warning with LRUCache::DisownData().
Closes https://github.com/facebook/rocksdb/pull/2783

Differential Revision: D5696465

Pulled By: yiwu-arbug

fbshipit-source-id: 87c607c002511fa089b18cc35e24909bee0e74b4
main
Yi Wu 7 years ago committed by Facebook Github Bot
parent 0980dc6c9a
commit e83d6a02e3
  1. 23
      cache/lru_cache.cc
  2. 4
      port/port_posix.cc

23
cache/lru_cache.cc vendored

@ -234,35 +234,19 @@ void LRUCacheShard::EvictFromLRU(size_t charge,
} }
void* LRUCacheShard::operator new(size_t size) { void* LRUCacheShard::operator new(size_t size) {
#if __SANITIZE_ADDRESS__
return malloc(size);
#else
return port::cacheline_aligned_alloc(size); return port::cacheline_aligned_alloc(size);
#endif
} }
void* LRUCacheShard::operator new[](size_t size) { void* LRUCacheShard::operator new[](size_t size) {
#if __SANITIZE_ADDRESS__
return malloc(size);
#else
return port::cacheline_aligned_alloc(size); return port::cacheline_aligned_alloc(size);
#endif
} }
void LRUCacheShard::operator delete(void *memblock) { void LRUCacheShard::operator delete(void *memblock) {
#if __SANITIZE_ADDRESS__
free(memblock);
#else
port::cacheline_aligned_free(memblock); port::cacheline_aligned_free(memblock);
#endif
} }
void LRUCacheShard::operator delete[](void* memblock) { void LRUCacheShard::operator delete[](void* memblock) {
#if __SANITIZE_ADDRESS__
free(memblock);
#else
port::cacheline_aligned_free(memblock); port::cacheline_aligned_free(memblock);
#endif
} }
void LRUCacheShard::SetCapacity(size_t capacity) { void LRUCacheShard::SetCapacity(size_t capacity) {
@ -518,7 +502,12 @@ uint32_t LRUCache::GetHash(Handle* handle) const {
return reinterpret_cast<const LRUHandle*>(handle)->hash; return reinterpret_cast<const LRUHandle*>(handle)->hash;
} }
void LRUCache::DisownData() { shards_ = nullptr; } void LRUCache::DisownData() {
// Do not drop data if compile with ASAN to suppress leak warning.
#ifndef __SANITIZE_ADDRESS__
shards_ = nullptr;
#endif // !__SANITIZE_ADDRESS__
}
size_t LRUCache::TEST_GetLRUSize() { size_t LRUCache::TEST_GetLRUSize() {
size_t lru_size_of_all_shards = 0; size_t lru_size_of_all_shards = 0;

@ -185,7 +185,9 @@ int GetMaxOpenFiles() {
} }
void *cacheline_aligned_alloc(size_t size) { void *cacheline_aligned_alloc(size_t size) {
#if defined (_ISOC11_SOURCE) #if __GNUC__ < 5 && defined(__SANITIZE_ADDRESS__)
return malloc(size);
#elif defined(_ISOC11_SOURCE)
return aligned_alloc(CACHE_LINE_SIZE, size); return aligned_alloc(CACHE_LINE_SIZE, size);
#elif ( _POSIX_C_SOURCE >= 200112L || _XOPEN_SOURCE >= 600 || defined(__APPLE__)) #elif ( _POSIX_C_SOURCE >= 200112L || _XOPEN_SOURCE >= 600 || defined(__APPLE__))
void *m; void *m;

Loading…
Cancel
Save