summaryrefslogtreecommitdiffstats
path: root/base
diff options
context:
space:
mode:
Diffstat (limited to 'base')
-rw-r--r--base/shared_memory.h5
-rw-r--r--base/shared_memory_posix.cc34
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.