summaryrefslogtreecommitdiffstats
path: root/base/shared_memory.h
diff options
context:
space:
mode:
authorrvargas@google.com <rvargas@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-02-11 01:32:58 +0000
committerrvargas@google.com <rvargas@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-02-11 01:32:58 +0000
commited1f53ed257c6f79d464092165d4d318c7e7f777 (patch)
tree8728e72810b6bde8cb1e9c39e7edf5376741de0a /base/shared_memory.h
parent7258924d59592745795ec1c12eafb20a30625826 (diff)
downloadchromium_src-ed1f53ed257c6f79d464092165d4d318c7e7f777.zip
chromium_src-ed1f53ed257c6f79d464092165d4d318c7e7f777.tar.gz
chromium_src-ed1f53ed257c6f79d464092165d4d318c7e7f777.tar.bz2
Fix a browser crash when the async resource handler keeps an
IOBuffer after a failed attempt to send the data to a (now gone) renderer. The shared memory section is unmapped so the buffer must not be kept around and possibly re-used. I'm also fixing a leak reported by purify. BUG=7487 BUG=7374 Review URL: http://codereview.chromium.org/21222 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@9540 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/shared_memory.h')
-rw-r--r--base/shared_memory.h2
1 files changed, 2 insertions, 0 deletions
diff --git a/base/shared_memory.h b/base/shared_memory.h
index ede36c5..3bfa003 100644
--- a/base/shared_memory.h
+++ b/base/shared_memory.h
@@ -113,6 +113,8 @@ class SharedMemory {
// bool ok = ShareToProcess(process, new_handle);
// Close();
// return ok;
+ // Note that the memory is unmapped by calling this method, regardless of the
+ // return value.
bool GiveToProcess(ProcessHandle process,
SharedMemoryHandle* new_handle) {
return ShareToProcessCommon(process, new_handle, true);