diff --git a/patches/v8/.patches b/patches/v8/.patches index 02b472b1a72d..7704cdbd32cb 100644 --- a/patches/v8/.patches +++ b/patches/v8/.patches @@ -2,3 +2,4 @@ chore_allow_customizing_microtask_policy_per_context.patch deps_add_v8_object_setinternalfieldfornodecore.patch revert_heap_add_checks_position_info.patch cherry-pick-f320600cd1f4.patch +cherry-pick-b3c01ac1e60a.patch diff --git a/patches/v8/cherry-pick-b3c01ac1e60a.patch b/patches/v8/cherry-pick-b3c01ac1e60a.patch new file mode 100644 index 000000000000..7b4ef2ad25f3 --- /dev/null +++ b/patches/v8/cherry-pick-b3c01ac1e60a.patch @@ -0,0 +1,76 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Shu-yu Guo +Date: Mon, 13 May 2024 11:23:20 -0700 +Subject: Don't build AccessInfo for storing to module exports + +Bug: 340221135 +Change-Id: I5af35be6ebf6a69db1c4687107503575b23973c4 +Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/5534518 +Reviewed-by: Adam Klein +Commit-Queue: Shu-yu Guo +Cr-Commit-Position: refs/heads/main@{#93872} + +diff --git a/src/compiler/access-info.cc b/src/compiler/access-info.cc +index 7cff878839c85cd9c6571ee48f1a0fce081f4471..9d022ba402d7bfdd5ca745a4193ee0de0e3d755e 100644 +--- a/src/compiler/access-info.cc ++++ b/src/compiler/access-info.cc +@@ -526,6 +526,14 @@ PropertyAccessInfo AccessorAccessInfoHelper( + Cell::cast(module_namespace->module()->exports()->Lookup( + isolate, name.object(), + Smi::ToInt(Object::GetHash(*name.object()))))); ++ if (IsAnyStore(access_mode)) { ++ // ES#sec-module-namespace-exotic-objects-set-p-v-receiver ++ // ES#sec-module-namespace-exotic-objects-defineownproperty-p-desc ++ // ++ // Storing to a module namespace object is always an error or a no-op in ++ // JS. ++ return PropertyAccessInfo::Invalid(zone); ++ } + if (IsTheHole(cell->value(kRelaxedLoad), isolate)) { + // This module has not been fully initialized yet. + return PropertyAccessInfo::Invalid(zone); +diff --git a/src/maglev/maglev-graph-builder.cc b/src/maglev/maglev-graph-builder.cc +index c5587be1e0b5d944d4b4b6f8d4f48f62c41db183..2a79c2bf27d18ee60b130bd0f8d6ff00493cab1e 100644 +--- a/src/maglev/maglev-graph-builder.cc ++++ b/src/maglev/maglev-graph-builder.cc +@@ -4116,19 +4116,28 @@ ReduceResult MaglevGraphBuilder::TryBuildPropertyStore( + access_info.holder().value()); + } + +- if (access_info.IsFastAccessorConstant()) { +- return TryBuildPropertySetterCall(access_info, receiver, +- GetAccumulatorTagged()); +- } else { +- DCHECK(access_info.IsDataField() || access_info.IsFastDataConstant()); +- ReduceResult res = TryBuildStoreField(access_info, receiver, access_mode); +- if (res.IsDone()) { +- RecordKnownProperty(receiver, name, +- current_interpreter_frame_.accumulator(), +- AccessInfoGuaranteedConst(access_info), access_mode); +- return res; ++ switch (access_info.kind()) { ++ case compiler::PropertyAccessInfo::kFastAccessorConstant: ++ return TryBuildPropertySetterCall(access_info, receiver, ++ GetAccumulatorTagged()); ++ case compiler::PropertyAccessInfo::kDataField: ++ case compiler::PropertyAccessInfo::kFastDataConstant: { ++ ReduceResult res = TryBuildStoreField(access_info, receiver, access_mode); ++ if (res.IsDone()) { ++ RecordKnownProperty( ++ receiver, name, current_interpreter_frame_.accumulator(), ++ AccessInfoGuaranteedConst(access_info), access_mode); ++ return res; ++ } ++ return ReduceResult::Fail(); + } +- return ReduceResult::Fail(); ++ case compiler::PropertyAccessInfo::kInvalid: ++ case compiler::PropertyAccessInfo::kNotFound: ++ case compiler::PropertyAccessInfo::kDictionaryProtoDataConstant: ++ case compiler::PropertyAccessInfo::kDictionaryProtoAccessorConstant: ++ case compiler::PropertyAccessInfo::kModuleExport: ++ case compiler::PropertyAccessInfo::kStringLength: ++ UNREACHABLE(); + } + } +