diff options
author | Paweł Hajdan <phajdan.jr@gentoo.org> | 2012-01-30 07:58:08 +0000 |
---|---|---|
committer | Paweł Hajdan <phajdan.jr@gentoo.org> | 2012-01-30 07:58:08 +0000 |
commit | 6fbd1a0c8ef9b0fa3786a7b89db97a2fc278193c (patch) | |
tree | 0c6f47a82e4e460eabea8f95c39cac72c21bd818 /www-client | |
parent | Version bump wrt bug #400717. Thanks to kensingtion <gentoo@scribeofthenile.c... (diff) | |
download | gentoo-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/ChangeLog | 10 | ||||
-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.patch | 193 |
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 + |