diff options
Diffstat (limited to 'base')
-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. |