mirror of
https://github.com/electron/electron.git
synced 2026-01-09 23:48:01 -05:00
* chore: bump chromium in DEPS to d5c9bf9e2a18fa508201a88e5803bec1d107b1ae * chore: bump chromium in DEPS to 45f1316afae33e52c92480b34bf4f7fe4a7db898 * update patches * WillCreateURLLoaderFactory now gets a ukm_source_id Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2346803 * ink_drop_visible_opacity -> GetInkDropVisibleOpacity Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2415368 * chore: bump chromium in DEPS to ddb5b6db5e35ab1a7b5adbd9f15373af6c35ea2a * 2418471: PDF Viewer update: Add missing aria-labels to various buttons. https://chromium-review.googlesource.com/c/chromium/src/+/2418471 * update printing.patch given print settings mojoification Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2409467 * update patches * content::BluetoothChooser::Event -> content::BluetoothChooserEvent Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2387901 * set_ink_drop_base_color -> SetInkDropBaseColor Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2419388 * chore: bump chromium in DEPS to ecf7c9ee830d4d85f300b461a2fa13aa40c79a4c * update patches * gfx::ConvertPointToPixel -> gfx::ConvertPointToPixels Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2418568 * remove ContentSettingsObserver::AllowStorage() Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2401847 * service_manager::kCrashDumpSignal -> kCrashDumpSignal Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2417073 * chore: bump chromium in DEPS to abdb7ebe5f8c8328b8f435283df90d0a3ecff7bd * chore: bump chromium in DEPS to 2a7e138ab1066534ceb2622e8a9d2c8ebf574215 * chore: bump chromium in DEPS to ab1884e75ced904e4276851eb4e1ad89919ca93b * chore: bump chromium in DEPS to a12413902380dcc2a73ac74d582328280a8af686 * Fixup printing patch https://chromium-review.googlesource.com/c/chromium/src/+/2428623 * Fixup OSR patch https://chromium-review.googlesource.com/c/chromium/src/+/2415128 * Make ExtensionURLLoaderFactory always owned by its |receivers_|. https://chromium-review.googlesource.com/c/chromium/src/+/2357523 * Add deprecated_default_sources_assignment_filter variable https://chromium-review.googlesource.com/c/chromium/src/+/2416496 * Fixup patch indices * Remove several references to BrowserPlugin from content https://chromium-review.googlesource.com/c/chromium/src/+/2401031 * Remove SurfaceEmbeddingTime and LocalSurfaceIdAllocation https://chromium-review.googlesource.com/c/chromium/src/+/2415128 * Add DragOperation and AllowedDragOperations Mojo types https://chromium-review.googlesource.com/c/chromium/src/+/2196167 * chore: bump chromium in DEPS to 378450342cf6aa160663d0ce3a178a11b570c25a * Fixup patch indices * Remove SurfaceEmbeddingTime and LocalSurfaceIdAllocation https://chromium-review.googlesource.com/c/chromium/src/+/2415128 * Add DragOperation and AllowedDragOperations Mojo types https://chromium-review.googlesource.com/c/chromium/src/+/2196167 * 2426564: Remove global sources assignment filter value https://chromium-review.googlesource.com/c/chromium/src/+/2426564 * Fixup blink_local_frame.patch * [XProto] Remove a subset of ui/gfx/x/x11.h https://chromium-review.googlesource.com/c/chromium/src/+/2430328 * Fixup patch indices * Remove several references to BrowserPlugin from content https://chromium-review.googlesource.com/c/chromium/src/+/2401031 * Remove lossy ConvertSizeToPixel() methods https://chromium-review.googlesource.com/c/chromium/src/+/2419534 * serial: Use USB driver name to disambiguate ports https://chromium-review.googlesource.com/c/chromium/src/+/2413176 * Remove set_sources_filter import * Fix ModMask usage * [XProto] Remove usage of all Xlib headers https://chromium-review.googlesource.com/c/chromium/src/+/2392140 * [XProto] Remove usage of Xlib Visuals https://chromium-review.googlesource.com/c/chromium/src/+/2429933 * Skip Angle manifest file https://chromium-review.googlesource.com/c/angle/angle/+/2425197 * Add whole src\third_party\angle\.git directory This directory is needed in order to properly generate gen/angle/angle_commit.h * [libvpx] Fix HighBD config on Windows ARM64 https://chromium-review.googlesource.com/c/chromium/src/+/2437745 * update patches * fix: correct calling convention for Windows on Arm https://chromium-review.googlesource.com/c/v8/v8/+/2440717 * Add third_party/angle/.git to the archive before adding the rest of the source * fixup source caching on Windows * Fixup erroneous close paren * fixup for goma issues * This should work * chore: bump chromium roll manually https://chromium-review.googlesource.com/c/chromium/src/+/2435142 This landed the day after we paused roller-bot and may resolve the visibility test flakes that we're seeing. h/t to @jkleinsc for finding this with me. * chore: remove obsoleted cherry-pick fix for libvpx https://chromium-review.googlesource.com/c/chromium/src/+/2437745 * chore: remove obsoleted cherry-pick libvpx patch https://chromium-review.googlesource.com/c/chromium/src/+/2437745 * chore: re-export patches * chore: add tracer comment to visibility-stat-spec. The line numbers between the source and the CI runs don't seem to match up, so this temp tracer is to help track the source of that difference. * chore: bump chromium in DEPS to 7c2b8cc3b8638aee8abeb013042a6c1d15b2da6b * update patches * impl SortingLSH service Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2425327 * 2446525: [Flash] Remove some Flash APIs https://chromium-review.googlesource.com/c/chromium/src/+/2446525 * 2440974: Reland "Delete service_manager/embedder/switches.h" https://chromium-review.googlesource.com/c/chromium/src/+/2440974 * 2359402: Remove ContentBrowserClient::NonNetworkURLLoaderFactoryDeprecatedMap. https://chromium-review.googlesource.com/c/chromium/src/+/2359402 * 2250506: Implement tabs.removeCSS https://chromium-review.googlesource.com/c/chromium/src/+/2250506 * 2429143: Remove implicit-conversion-to-integer ConvertRectToPixel() methods. https://chromium-review.googlesource.com/c/chromium/src/+/2429143 * 2444430: Remove DataElementType::kBlob https://chromium-review.googlesource.com/c/chromium/src/+/2444430 * 2441964: Clean up WebView public API https://chromium-review.googlesource.com/c/chromium/src/+/2441964 * 2357523: Make ExtensionURLLoaderFactory always owned by its |receivers_|. https://chromium-review.googlesource.com/c/chromium/src/+/2357523 * 2461606: Use blink::mojom::PreferredColorScheme instead of blink::PreferredColorScheme https://chromium-review.googlesource.com/c/chromium/src/+/2461606 * 2461235: a11y inspect reorg: move PropertyFilter struct to a new location https://chromium-review.googlesource.com/c/chromium/src/+/2461235 * remove flash support * fix frame_host_manager patch * fix lint * remove flash info from docs * fix build * fix osr * chore: bump chromium in DEPS to 9269f9eb1d98d29564c2b2ab97f30c6e148c4e11 * fix visibilityState tests * 2463049: Replace all uses of web_pref::AutoplayPolicy with mojom::AutoplayPolicy https://chromium-review.googlesource.com/c/chromium/src/+/2463049 * update patches * fix tests harder * 2414921: Add Group and Ungroup functions to Tabs extension API https://chromium-review.googlesource.com/c/chromium/src/+/2414921 * more test fix * Remove all keyboard related usage of Xlib Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2436787 * fix linux build * 2453807: [XProto] Remove usage of Xlib error handling https://chromium-review.googlesource.com/c/chromium/src/+/2453807 * lint * fixup! 2453807: [XProto] Remove usage of Xlib error handling * disable CalculateNativeWinOcclusion on win ci * remove UploadBlob from docs * Update appveyor.yml Co-authored-by: Andy Locascio <andy@slack-corp.com> Co-authored-by: John Kleinschmidt <jkleinsc@github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: Jeremy Rose <nornagon@nornagon.net> Co-authored-by: Electron Bot <anonymous@electronjs.org> Co-authored-by: Charles Kerr <charles@charleskerr.com> Co-authored-by: Samuel Attard <samuel.r.attard@gmail.com> Co-authored-by: Jeremy Rose <jeremya@chromium.org>
135 lines
6.1 KiB
Diff
135 lines
6.1 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Samuel Attard <marshallofsound@electronjs.org>
|
|
Date: Mon, 6 Jul 2020 20:47:43 -0700
|
|
Subject: chore: add v8 apple silicon patches
|
|
|
|
Once these are available upstream we can remove this patch.
|
|
|
|
diff --git a/src/codegen/arm64/macro-assembler-arm64.cc b/src/codegen/arm64/macro-assembler-arm64.cc
|
|
index fef1758aaa81a85009461839ec9aa816e7d196a6..c0f7a1cf5fd4787896b06bce911aabf17b290e88 100644
|
|
--- a/src/codegen/arm64/macro-assembler-arm64.cc
|
|
+++ b/src/codegen/arm64/macro-assembler-arm64.cc
|
|
@@ -2975,6 +2975,35 @@ void TurboAssembler::PrintfNoPreserve(const char* format,
|
|
|
|
int arg_count = kPrintfMaxArgCount;
|
|
|
|
+#if V8_OS_MACOSX && !USE_SIMULATOR
|
|
+ CPURegList tmp_list = kCallerSaved;
|
|
+ tmp_list.Remove(x0); // Used to pass the format string.
|
|
+ tmp_list.Remove(arg0, arg1, arg2, arg3);
|
|
+
|
|
+ // Override the MacroAssembler's scratch register list. The lists will be
|
|
+ // reset automatically at the end of the UseScratchRegisterScope.
|
|
+ UseScratchRegisterScope temps(this);
|
|
+ TmpList()->set_list(tmp_list.list());
|
|
+
|
|
+ VRegister temp_D = temps.AcquireD();
|
|
+
|
|
+ // https://developer.apple.com/library/archive/documentation/Xcode/Conceptual/iPhoneOSABIReference/Articles/ARM64FunctionCallingConventions.html#//apple_ref/doc/uid/TP40013702-SW1
|
|
+ Claim(kPrintfMaxArgCount, 8);
|
|
+ int64_t offset = 0;
|
|
+ for (unsigned i = 0; i < kPrintfMaxArgCount; i++) {
|
|
+ CPURegister arg = args[i];
|
|
+ if (arg.IsNone()) {
|
|
+ break;
|
|
+ }
|
|
+ if (arg.IsS()) {
|
|
+ fcvt(temp_D, arg.S());
|
|
+ arg = temp_D;
|
|
+ }
|
|
+ // FIXME: Use stp.
|
|
+ str(arg, MemOperand(sp, offset, Offset));
|
|
+ offset += 8;
|
|
+ }
|
|
+#else
|
|
// The PCS varargs registers for printf. Note that x0 is used for the printf
|
|
// format string.
|
|
static const CPURegList kPCSVarargs =
|
|
@@ -3085,7 +3114,7 @@ void TurboAssembler::PrintfNoPreserve(const char* format,
|
|
}
|
|
#endif
|
|
}
|
|
-
|
|
+#endif
|
|
// Load the format string into x0, as per the procedure-call standard.
|
|
//
|
|
// To make the code as portable as possible, the format string is encoded
|
|
@@ -3107,6 +3136,10 @@ void TurboAssembler::PrintfNoPreserve(const char* format,
|
|
}
|
|
|
|
CallPrintf(arg_count, pcs);
|
|
+
|
|
+#if V8_OS_MACOSX && !USE_SIMULATOR
|
|
+ Drop(kPrintfMaxArgCount, 8);
|
|
+#endif
|
|
}
|
|
|
|
void TurboAssembler::CallPrintf(int arg_count, const CPURegister* args) {
|
|
diff --git a/src/compiler/backend/arm64/instruction-selector-arm64.cc b/src/compiler/backend/arm64/instruction-selector-arm64.cc
|
|
index 78ae11f0d17c156b3debd1d501a22edc42c9fff5..564e6a1a71073727fe6daa847093c556c532620b 100644
|
|
--- a/src/compiler/backend/arm64/instruction-selector-arm64.cc
|
|
+++ b/src/compiler/backend/arm64/instruction-selector-arm64.cc
|
|
@@ -1905,6 +1905,7 @@ void InstructionSelector::EmitPrepareArguments(
|
|
|
|
// Poke the arguments into the stack.
|
|
while (slot >= 0) {
|
|
+ // FIXME: In the Apple ARM64 ABI parameters should be packed on the stack.
|
|
PushParameter input0 = (*arguments)[slot];
|
|
PushParameter input1 = slot > 0 ? (*arguments)[slot - 1] : PushParameter();
|
|
// Emit a poke-pair if consecutive parameters have the same type.
|
|
diff --git a/src/flags/flag-definitions.h b/src/flags/flag-definitions.h
|
|
index 3137eb2ad31847efb9a0c526a2e0f84209d71cfe..723845eee8439f6dc8b5d1de3cc578ecdd1d3e99 100644
|
|
--- a/src/flags/flag-definitions.h
|
|
+++ b/src/flags/flag-definitions.h
|
|
@@ -776,7 +776,12 @@ DEFINE_INT(wasm_num_compilation_tasks, 128,
|
|
"maximum number of parallel compilation tasks for wasm")
|
|
DEFINE_DEBUG_BOOL(trace_wasm_native_heap, false,
|
|
"trace wasm native heap events")
|
|
-DEFINE_BOOL(wasm_write_protect_code_memory, false,
|
|
+#if V8_OS_MACOSX && V8_TARGET_ARCH_ARM64
|
|
+#define V8_DEFAULT_WASM_WRITE_PROTECT_CODE_MEMORY true
|
|
+#else
|
|
+#define V8_DEFAULT_WASM_WRITE_PROTECT_CODE_MEMORY false
|
|
+#endif
|
|
+DEFINE_BOOL(wasm_write_protect_code_memory, V8_DEFAULT_WASM_WRITE_PROTECT_CODE_MEMORY,
|
|
"write protect code memory on the wasm native heap")
|
|
DEFINE_DEBUG_BOOL(trace_wasm_serialization, false,
|
|
"trace serialization/deserialization")
|
|
diff --git a/src/wasm/function-compiler.cc b/src/wasm/function-compiler.cc
|
|
index 5c35f69f2af2199025dddfa577564996dbb6145f..a4e6b0128e909d371d0ede3627494002e281d547 100644
|
|
--- a/src/wasm/function-compiler.cc
|
|
+++ b/src/wasm/function-compiler.cc
|
|
@@ -258,6 +258,7 @@ void WasmCompilationUnit::CompileWasmFunction(Isolate* isolate,
|
|
isolate->counters(), detected);
|
|
if (result.succeeded()) {
|
|
WasmCodeRefScope code_ref_scope;
|
|
+ NativeModuleModificationScope native_module_modification_scope(native_module);
|
|
native_module->PublishCode(
|
|
native_module->AddCompiledCode(std::move(result)));
|
|
} else {
|
|
diff --git a/src/wasm/wasm-code-manager.h b/src/wasm/wasm-code-manager.h
|
|
index 5e8ed5475bb064cb657069242ce7517de7f5f8e2..5652bb407da3646e55c42492b3e9facec4556367 100644
|
|
--- a/src/wasm/wasm-code-manager.h
|
|
+++ b/src/wasm/wasm-code-manager.h
|
|
@@ -886,7 +886,7 @@ class V8_EXPORT_PRIVATE WasmCodeManager final {
|
|
// and even if we did, the resulting set of pages may be fragmented.
|
|
// Currently, we try and keep the number of syscalls low.
|
|
// - similar argument for debug time.
|
|
-class NativeModuleModificationScope final {
|
|
+class V8_EXPORT_PRIVATE NativeModuleModificationScope final {
|
|
public:
|
|
explicit NativeModuleModificationScope(NativeModule* native_module);
|
|
~NativeModuleModificationScope();
|
|
diff --git a/src/wasm/wasm-objects.cc b/src/wasm/wasm-objects.cc
|
|
index 0666f88619b9e724fe79d8fad817b8acf99a01b7..5274cad0d0aed50bbdea66ff1666af556d994879 100644
|
|
--- a/src/wasm/wasm-objects.cc
|
|
+++ b/src/wasm/wasm-objects.cc
|
|
@@ -1512,6 +1512,7 @@ void WasmInstanceObject::ImportWasmJSFunctionIntoTable(
|
|
wasm::WasmCompilationResult result = compiler::CompileWasmImportCallWrapper(
|
|
isolate->wasm_engine(), &env, kind, sig, false,
|
|
shared.internal_formal_parameter_count());
|
|
+ wasm::NativeModuleModificationScope native_module_modification_scope(native_module);
|
|
std::unique_ptr<wasm::WasmCode> wasm_code = native_module->AddCode(
|
|
result.func_index, result.code_desc, result.frame_slot_count,
|
|
result.tagged_parameter_slots,
|