summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaweł Hajdan <phajdan.jr@gentoo.org>2012-01-30 07:58:08 +0000
committerPaweł Hajdan <phajdan.jr@gentoo.org>2012-01-30 07:58:08 +0000
commit6fbd1a0c8ef9b0fa3786a7b89db97a2fc278193c (patch)
tree0c6f47a82e4e460eabea8f95c39cac72c21bd818 /www-client
parentVersion bump wrt bug #400717. Thanks to kensingtion <gentoo@scribeofthenile.c... (diff)
downloadgentoo-2-6fbd1a0c8ef9b0fa3786a7b89db97a2fc278193c.tar.gz
gentoo-2-6fbd1a0c8ef9b0fa3786a7b89db97a2fc278193c.tar.bz2
gentoo-2-6fbd1a0c8ef9b0fa3786a7b89db97a2fc278193c.zip
Backport upstream fix for Gentoo bug #389479, and suppress net_unittests failure that doesn't occur in 18.x. Remove old.
(Portage version: 2.1.10.44/cvs/Linux i686)
Diffstat (limited to 'www-client')
-rw-r--r--www-client/chromium/ChangeLog10
-rw-r--r--www-client/chromium/chromium-17.0.963.44-r1.ebuild (renamed from www-client/chromium/chromium-17.0.963.38.ebuild)8
-rw-r--r--www-client/chromium/files/chromium-dev-shm-r0.patch193
3 files changed, 208 insertions, 3 deletions
diff --git a/www-client/chromium/ChangeLog b/www-client/chromium/ChangeLog
index 832dc1692161..c0581a208f1e 100644
--- a/www-client/chromium/ChangeLog
+++ b/www-client/chromium/ChangeLog
@@ -1,6 +1,14 @@
# ChangeLog for www-client/chromium
# Copyright 1999-2012 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/www-client/chromium/ChangeLog,v 1.547 2012/01/26 04:17:23 floppym Exp $
+# $Header: /var/cvsroot/gentoo-x86/www-client/chromium/ChangeLog,v 1.548 2012/01/30 07:58:08 phajdan.jr Exp $
+
+*chromium-17.0.963.44-r1 (30 Jan 2012)
+
+ 30 Jan 2012; Pawel Hajdan jr <phajdan.jr@gentoo.org>
+ +files/chromium-dev-shm-r0.patch, -chromium-17.0.963.38.ebuild,
+ +chromium-17.0.963.44-r1.ebuild:
+ Backport upstream fix for Gentoo bug #389479, and suppress net_unittests
+ failure that doesn't occur in 18.x. Remove old.
*chromium-17.0.963.44 (26 Jan 2012)
diff --git a/www-client/chromium/chromium-17.0.963.38.ebuild b/www-client/chromium/chromium-17.0.963.44-r1.ebuild
index d74d66f8bb30..fda658190bed 100644
--- a/www-client/chromium/chromium-17.0.963.38.ebuild
+++ b/www-client/chromium/chromium-17.0.963.44-r1.ebuild
@@ -1,6 +1,6 @@
# Copyright 1999-2012 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/www-client/chromium/chromium-17.0.963.38.ebuild,v 1.1 2012/01/19 02:09:39 floppym Exp $
+# $Header: /var/cvsroot/gentoo-x86/www-client/chromium/chromium-17.0.963.44-r1.ebuild,v 1.1 2012/01/30 07:58:08 phajdan.jr Exp $
EAPI="4"
PYTHON_DEPEND="2:2.6"
@@ -188,6 +188,9 @@ src_prepare() {
# Revert WebKit changeset responsible for Gentoo bug #393471.
epatch "${FILESDIR}/${PN}-revert-jpeg-swizzle-r0.patch"
+ # Backport upstream fix for Gentoo bug #389479.
+ epatch "${FILESDIR}/${PN}-dev-shm-r0.patch"
+
epatch_user
# Remove most bundled libraries. Some are still needed.
@@ -380,8 +383,9 @@ src_test() {
# NetUtilTest: bug #361885.
# NetUtilTest.GenerateFileName: some locale-related mismatch.
# UDP: unstable, active development. We should revisit this later.
+ # CertDatabaseNSSTest.ImportCACertHierarchyTree: works in 18.x, broken here.
LC_ALL="${mylocale}" VIRTUALX_COMMAND=out/Release/net_unittests virtualmake \
- '--gtest_filter=-NetUtilTest.IDNToUnicode*:NetUtilTest.FormatUrl*:NetUtilTest.GenerateFileName:*UDP*'
+ '--gtest_filter=-NetUtilTest.IDNToUnicode*:NetUtilTest.FormatUrl*:NetUtilTest.GenerateFileName:*UDP*:CertDatabaseNSSTest.ImportCACertHierarchyTree'
LC_ALL="${mylocale}" VIRTUALX_COMMAND=out/Release/printing_unittests virtualmake
}
diff --git a/www-client/chromium/files/chromium-dev-shm-r0.patch b/www-client/chromium/files/chromium-dev-shm-r0.patch
new file mode 100644
index 000000000000..2c4c2b7eaace
--- /dev/null
+++ b/www-client/chromium/files/chromium-dev-shm-r0.patch
@@ -0,0 +1,193 @@
+Backport http://codereview.chromium.org/8800025 to fix issues with noexec /dev/shm
+diff --git a/base/file_util.h b/base/file_util.h
+index 90ec1ae..78827e9 100644
+--- a/base/file_util.h
++++ b/base/file_util.h
+@@ -259,7 +259,7 @@ BASE_EXPORT bool IsDirectoryEmpty(const FilePath& dir_path);
+ BASE_EXPORT bool GetTempDir(FilePath* path);
+ // Get a temporary directory for shared memory files.
+ // Only useful on POSIX; redirects to GetTempDir() on Windows.
+-BASE_EXPORT bool GetShmemTempDir(FilePath* path);
++BASE_EXPORT bool GetShmemTempDir(FilePath* path, bool executable);
+
+ // Get the home directory. This is more complicated than just getenv("HOME")
+ // as it knows to fall back on getpwent() etc.
+@@ -279,7 +279,10 @@ BASE_EXPORT bool CreateTemporaryFileInDir(const FilePath& dir,
+ // Returns a handle to the opened file or NULL if an error occured.
+ BASE_EXPORT FILE* CreateAndOpenTemporaryFile(FilePath* path);
+ // Like above but for shmem files. Only useful for POSIX.
+-BASE_EXPORT FILE* CreateAndOpenTemporaryShmemFile(FilePath* path);
++// The executable flag says the file needs to support using
++// mprotect with PROT_EXEC after mapping.
++BASE_EXPORT FILE* CreateAndOpenTemporaryShmemFile(FilePath* path,
++ bool executable);
+ // Similar to CreateAndOpenTemporaryFile, but the file is created in |dir|.
+ BASE_EXPORT FILE* CreateAndOpenTemporaryFileInDir(const FilePath& dir,
+ FilePath* path);
+diff --git a/base/file_util_android.cc b/base/file_util_android.cc
+index eff3a46..6807d8d 100644
+--- a/base/file_util_android.cc
++++ b/base/file_util_android.cc
+@@ -8,7 +8,7 @@
+
+ namespace file_util {
+
+-bool GetShmemTempDir(FilePath* path) {
++bool GetShmemTempDir(FilePath* path, bool executable) {
+ *path = FilePath("/data/local/tmp");
+ return true;
+ }
+diff --git a/base/file_util_mac.mm b/base/file_util_mac.mm
+index 95d4f25..bb4975d 100644
+--- a/base/file_util_mac.mm
++++ b/base/file_util_mac.mm
+@@ -1,4 +1,4 @@
+-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
++// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+ // Use of this source code is governed by a BSD-style license that can be
+ // found in the LICENSE file.
+
+@@ -22,7 +22,7 @@ bool GetTempDir(FilePath* path) {
+ return true;
+ }
+
+-bool GetShmemTempDir(FilePath* path) {
++bool GetShmemTempDir(FilePath* path, bool executable) {
+ return GetTempDir(path);
+ }
+
+diff --git a/base/file_util_posix.cc b/base/file_util_posix.cc
+index 582f70e..5c14abd 100644
+--- a/base/file_util_posix.cc
++++ b/base/file_util_posix.cc
+@@ -481,9 +481,9 @@ bool CreateTemporaryFile(FilePath* path) {
+ return true;
+ }
+
+-FILE* CreateAndOpenTemporaryShmemFile(FilePath* path) {
++FILE* CreateAndOpenTemporaryShmemFile(FilePath* path, bool executable) {
+ FilePath directory;
+- if (!GetShmemTempDir(&directory))
++ if (!GetShmemTempDir(&directory, executable))
+ return NULL;
+
+ return CreateAndOpenTemporaryFileInDir(directory, path);
+@@ -910,15 +910,52 @@ bool GetTempDir(FilePath* path) {
+ }
+
+ #if !defined(OS_ANDROID)
+-bool GetShmemTempDir(FilePath* path) {
++
+ #if defined(OS_LINUX)
+- *path = FilePath("/dev/shm");
+- return true;
+-#else
+- return GetTempDir(path);
+-#endif
++// Determine if /dev/shm files can be mapped and then mprotect'd PROT_EXEC.
++// This depends on the mount options used for /dev/shm, which vary among
++// different Linux distributions and possibly local configuration. It also
++// depends on details of kernel--ChromeOS uses the noexec option for /dev/shm
++// but its kernel allows mprotect with PROT_EXEC anyway.
++
++namespace {
++
++bool DetermineDevShmExecutable() {
++ bool result = false;
++ FilePath path;
++ int fd = CreateAndOpenFdForTemporaryFile(FilePath("/dev/shm"), &path);
++ if (fd >= 0) {
++ ScopedFD shm_fd_closer(&fd);
++ Delete(path, false);
++ size_t pagesize = sysconf(_SC_PAGESIZE);
++ void *mapping = mmap(NULL, pagesize, PROT_READ, MAP_SHARED, fd, 0);
++ if (mapping != MAP_FAILED) {
++ if (mprotect(mapping, pagesize, PROT_READ | PROT_EXEC) == 0)
++ result = true;
++ munmap(mapping, pagesize);
++ }
++ }
++ return result;
+ }
++
++}; // namespace
++#endif // defined(OS_LINUX)
++
++bool GetShmemTempDir(FilePath* path, bool executable) {
++#if defined(OS_LINUX)
++ bool use_dev_shm = true;
++ if (executable) {
++ static const bool s_dev_shm_executable = DetermineDevShmExecutable();
++ use_dev_shm = s_dev_shm_executable;
++ }
++ if (use_dev_shm) {
++ *path = FilePath("/dev/shm");
++ return true;
++ }
+ #endif
++ return GetTempDir(path);
++}
++#endif // !defined(OS_ANDROID)
+
+ FilePath GetHomeDir() {
+ const char* home_dir = getenv("HOME");
+diff --git a/base/file_util_unittest.cc b/base/file_util_unittest.cc
+index 00cacd6..a9f9377 100644
+--- a/base/file_util_unittest.cc
++++ b/base/file_util_unittest.cc
+@@ -1545,7 +1545,7 @@ TEST_F(FileUtilTest, CreateNewTemporaryDirInDirTest) {
+
+ TEST_F(FileUtilTest, GetShmemTempDirTest) {
+ FilePath dir;
+- EXPECT_TRUE(file_util::GetShmemTempDir(&dir));
++ EXPECT_TRUE(file_util::GetShmemTempDir(&dir, false));
+ EXPECT_TRUE(file_util::DirectoryExists(dir));
+ }
+
+diff --git a/base/file_util_win.cc b/base/file_util_win.cc
+index 8d9fbde..a6720a5 100644
+--- a/base/file_util_win.cc
++++ b/base/file_util_win.cc
+@@ -556,7 +556,7 @@ bool GetTempDir(FilePath* path) {
+ return true;
+ }
+
+-bool GetShmemTempDir(FilePath* path) {
++bool GetShmemTempDir(FilePath* path, bool executable) {
+ return GetTempDir(path);
+ }
+
+@@ -576,7 +576,7 @@ bool CreateTemporaryFile(FilePath* path) {
+ return false;
+ }
+
+-FILE* CreateAndOpenTemporaryShmemFile(FilePath* path) {
++FILE* CreateAndOpenTemporaryShmemFile(FilePath* path, bool executable) {
+ base::ThreadRestrictions::AssertIOAllowed();
+ return CreateAndOpenTemporaryFile(path);
+ }
+diff --git a/base/shared_memory_posix.cc b/base/shared_memory_posix.cc
+index 030061a..a66c859 100644
+--- a/base/shared_memory_posix.cc
++++ b/base/shared_memory_posix.cc
+@@ -123,7 +123,7 @@ bool SharedMemory::Create(const SharedMemoryCreateOptions& options) {
+ DCHECK(!options.open_existing);
+ // 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);
++ fp = file_util::CreateAndOpenTemporaryShmemFile(&path, options.executable);
+
+ // Deleting the file prevents anyone else from mapping it in
+ // (making it private), and prevents the need for cleanup (once
+@@ -317,7 +317,7 @@ bool SharedMemory::FilePathForMemoryName(const std::string& mem_name,
+ DCHECK_EQ(std::string::npos, mem_name.find('\0'));
+
+ FilePath temp_dir;
+- if (!file_util::GetShmemTempDir(&temp_dir))
++ if (!file_util::GetShmemTempDir(&temp_dir, false))
+ return false;
+
+ #if !defined(OS_MACOSX)
+--
+1.7.6.1
+