chore: cherry-pick 0c8b6e41 from v8 (#27672)
* chore: cherry-pick 0c8b6e41 from v8 Backports https://chromium-review.googlesource.com/c/v8/v8/+/2679688 * update patches Co-authored-by: Electron Bot <electron@github.com>
This commit is contained in:
parent
af4a050a1b
commit
44460e84c0
2 changed files with 43 additions and 0 deletions
|
@ -8,3 +8,4 @@ do_not_export_private_v8_symbols_on_windows.patch
|
||||||
revert_cleanup_switch_offset_of_to_offsetof_where_possible.patch
|
revert_cleanup_switch_offset_of_to_offsetof_where_possible.patch
|
||||||
fix_build_deprecated_attirbute_for_older_msvc_versions.patch
|
fix_build_deprecated_attirbute_for_older_msvc_versions.patch
|
||||||
chore_disallow_copying_cppheapcreateparams.patch
|
chore_disallow_copying_cppheapcreateparams.patch
|
||||||
|
mac_wasm_work_around_macos_11_2_code_page_decommit_failures.patch
|
||||||
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: deepak1556 <hop2deep@gmail.com>
|
||||||
|
Date: Mon, 8 Feb 2021 13:20:09 -0800
|
||||||
|
Subject: Work around MacOS 11.2 code page decommit failures
|
||||||
|
|
||||||
|
MacOS 11.2 refuses to set "no access" permissions on memory that
|
||||||
|
we previously used for JIT-compiled code. It is still unclear
|
||||||
|
whether this is WAI on the part of the kernel. In the meantime,
|
||||||
|
as a workaround, we use madvise(..., MADV_FREE_REUSABLE) instead
|
||||||
|
of mprotect(..., NONE) when discarding code pages. This is inspired
|
||||||
|
by what Chromium's gin platform does.
|
||||||
|
|
||||||
|
Fixed: v8:11389
|
||||||
|
Change-Id: I866586932573b4253002436ae5eee4e0411c45fc
|
||||||
|
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2679688
|
||||||
|
Commit-Queue: Jakob Kummerow <jkummerow@chromium.org>
|
||||||
|
Commit-Queue: Michael Lippautz <mlippautz@chromium.org>
|
||||||
|
Auto-Submit: Jakob Kummerow <jkummerow@chromium.org>
|
||||||
|
Reviewed-by: Michael Lippautz <mlippautz@chromium.org>
|
||||||
|
Cr-Commit-Position: refs/heads/master@{#72559}
|
||||||
|
|
||||||
|
diff --git a/src/base/platform/platform-posix.cc b/src/base/platform/platform-posix.cc
|
||||||
|
index ab0d7839a453d87a8404ca791c1022871e8fd606..67746173d582c5c404083be8ef3fa36c7dfc8cfe 100644
|
||||||
|
--- a/src/base/platform/platform-posix.cc
|
||||||
|
+++ b/src/base/platform/platform-posix.cc
|
||||||
|
@@ -415,6 +415,16 @@ bool OS::SetPermissions(void* address, size_t size, MemoryPermission access) {
|
||||||
|
|
||||||
|
int prot = GetProtectionFromMemoryPermission(access);
|
||||||
|
int ret = mprotect(address, size, prot);
|
||||||
|
+
|
||||||
|
+ // MacOS 11.2 on Apple Silicon refuses to switch permissions from
|
||||||
|
+ // rwx to none. Just use madvise instead.
|
||||||
|
+#if defined(V8_OS_MACOSX)
|
||||||
|
+ if (ret != 0 && access == OS::MemoryPermission::kNoAccess) {
|
||||||
|
+ ret = madvise(address, size, MADV_FREE_REUSABLE);
|
||||||
|
+ return ret == 0;
|
||||||
|
+ }
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
if (ret == 0 && access == OS::MemoryPermission::kNoAccess) {
|
||||||
|
// This is advisory; ignore errors and continue execution.
|
||||||
|
USE(DiscardSystemPages(address, size));
|
Loading…
Reference in a new issue