diff options
author | mbelshe@google.com <mbelshe@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-09 02:21:48 +0000 |
---|---|---|
committer | mbelshe@google.com <mbelshe@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-09 02:21:48 +0000 |
commit | 31cc2fdd5f43c4c6a0c0ebe0679458ecb3ba1593 (patch) | |
tree | 9419df0f203d66fc93dbbed6f400ea5a16ea5902 | |
parent | 84934a22839e7b16451ac37afc8b2b260d04edaa (diff) | |
download | chromium_src-31cc2fdd5f43c4c6a0c0ebe0679458ecb3ba1593.zip chromium_src-31cc2fdd5f43c4c6a0c0ebe0679458ecb3ba1593.tar.gz chromium_src-31cc2fdd5f43c4c6a0c0ebe0679458ecb3ba1593.tar.bz2 |
Fix realloc to not call the new_handler (which is for failures)
when the request was for realloc(ptr, 0). Calling realloc(ptr, 0)
is valid, and we should delete ptr and return NULL.
BUG=none
TEST=none
Review URL: http://codereview.chromium.org/194040
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@25700 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | third_party/tcmalloc/allocator_shim.cc | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/third_party/tcmalloc/allocator_shim.cc b/third_party/tcmalloc/allocator_shim.cc index 9877059..f5bc306 100644 --- a/third_party/tcmalloc/allocator_shim.cc +++ b/third_party/tcmalloc/allocator_shim.cc @@ -160,7 +160,11 @@ void* realloc(void* ptr, size_t size) __THROW { // TCMalloc case. new_ptr = do_realloc(ptr, size); #endif - if (new_ptr) + + // Subtle warning: NULL return does not alwas indicate out-of-memory. If + // the requested new size is zero, realloc should free the ptr and return + // NULL. + if (new_ptr || !size) return new_ptr; if (!new_mode || !call_new_handler(true)) break; |