diff options
author | evan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-16 17:32:11 +0000 |
---|---|---|
committer | evan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-16 17:32:11 +0000 |
commit | abd97e42913a8713d53c4361840022a4eaa74e8c (patch) | |
tree | 51373e67c1dc0ba2821ac30edcf09b0dbc4e6aaa | |
parent | 3224dcddf987d47154c3232d1974a9d4ba517c8a (diff) | |
download | chromium_src-abd97e42913a8713d53c4361840022a4eaa74e8c.zip chromium_src-abd97e42913a8713d53c4361840022a4eaa74e8c.tar.gz chromium_src-abd97e42913a8713d53c4361840022a4eaa74e8c.tar.bz2 |
posix: clean up shared memory code
At first I rewrote this to use the shm_*() family of
functions, but that doesn't work on OS X. Now I've just
cleaned up some bits and added an extra print to help with
the below bug.
BUG=16371
Review URL: http://codereview.chromium.org/204024
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@26361 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | base/shared_memory.h | 5 | ||||
-rw-r--r-- | base/shared_memory_posix.cc | 34 |
2 files changed, 21 insertions, 18 deletions
diff --git a/base/shared_memory.h b/base/shared_memory.h index ea72069..90bed59 100644 --- a/base/shared_memory.h +++ b/base/shared_memory.h @@ -17,6 +17,8 @@ #include "base/basictypes.h" #include "base/process.h" +class FilePath; + namespace base { // SharedMemoryHandle is a platform specific type which represents @@ -160,8 +162,7 @@ class SharedMemory { private: #if defined(OS_POSIX) bool CreateOrOpen(const std::wstring &name, int posix_flags, size_t size); - bool FilenameForMemoryName(const std::wstring &memname, - std::wstring *filename); + bool FilePathForMemoryName(const std::wstring& memname, FilePath* path); void LockOrUnlockCommon(int function); #endif diff --git a/base/shared_memory_posix.cc b/base/shared_memory_posix.cc index 20a1ccb..8828b10 100644 --- a/base/shared_memory_posix.cc +++ b/base/shared_memory_posix.cc @@ -96,11 +96,10 @@ bool SharedMemory::Create(const std::wstring &name, bool read_only, // These files need to be deleted explicitly. // In practice this call is only needed for unit tests. bool SharedMemory::Delete(const std::wstring& name) { - std::wstring mem_filename; - if (FilenameForMemoryName(name, &mem_filename) == false) + FilePath path; + if (!FilePathForMemoryName(name, &path)) return false; - FilePath path(WideToUTF8(mem_filename)); if (file_util::PathExists(path)) { return file_util::Delete(path, false); } @@ -121,10 +120,8 @@ bool SharedMemory::Open(const std::wstring &name, bool read_only) { // For the given shmem named |memname|, return a filename to mmap() // (and possibly create). Modifies |filename|. Return false on // error, or true of we are happy. -bool SharedMemory::FilenameForMemoryName(const std::wstring &memname, - std::wstring *filename) { - std::wstring mem_filename; - +bool SharedMemory::FilePathForMemoryName(const std::wstring& memname, + FilePath* path) { // mem_name will be used for a filename; make sure it doesn't // contain anything which will confuse us. DCHECK(memname.find_first_of(L"/") == std::string::npos); @@ -134,9 +131,8 @@ bool SharedMemory::FilenameForMemoryName(const std::wstring &memname, if (file_util::GetShmemTempDir(&temp_dir) == false) return false; - mem_filename = UTF8ToWide(temp_dir.value()); - file_util::AppendToPath(&mem_filename, L"com.google.chrome.shmem." + memname); - *filename = mem_filename; + *path = temp_dir.AppendASCII("com.google.chrome.shmem." + + WideToASCII(memname)); return true; } @@ -145,7 +141,7 @@ bool SharedMemory::FilenameForMemoryName(const std::wstring &memname, // TODO(jrg): there is no way to "clean up" all unused named shmem if // we restart from a crash. (That isn't a new problem, but it is a problem.) // In case we want to delete it later, it may be useful to save the value -// of mem_filename after FilenameForMemoryName(). +// of mem_filename after FilePathForMemoryName(). bool SharedMemory::CreateOrOpen(const std::wstring &name, int posix_flags, size_t size) { DCHECK(mapped_file_ == -1); @@ -153,11 +149,13 @@ bool SharedMemory::CreateOrOpen(const std::wstring &name, file_util::ScopedFILE file_closer; FILE *fp; + FilePath path; if (name == L"") { // It doesn't make sense to have a read-only private piece of shmem DCHECK(posix_flags & (O_RDWR | O_WRONLY)); - FilePath path; + // Q: Why not use the shm_open() etc. APIs? + // A: Because they're limited to 4mb on OS X. FFFFFFFUUUUUUUUUUU fp = file_util::CreateAndOpenTemporaryShmemFile(&path); // Deleting the file prevents anyone else from mapping it in @@ -165,8 +163,7 @@ bool SharedMemory::CreateOrOpen(const std::wstring &name, // the last fd is closed, it is truly freed). file_util::Delete(path, false); } else { - std::wstring mem_filename; - if (FilenameForMemoryName(name, &mem_filename) == false) + if (!FilePathForMemoryName(name, &path)) return false; std::string mode; @@ -186,11 +183,16 @@ bool SharedMemory::CreateOrOpen(const std::wstring &name, break; } - fp = file_util::OpenFile(mem_filename, mode.c_str()); + fp = file_util::OpenFile(path, mode.c_str()); } - if (fp == NULL) + if (fp == NULL) { + if (posix_flags & O_CREAT) + LOG(ERROR) << "Creating shared memory in " << path.value() << " failed: " + << strerror(errno); return false; + } + file_closer.reset(fp); // close when we go out of scope // Make sure the (new) file is the right size. |