Commit 6cf94ebd authored by bmeurer's avatar bmeurer Committed by Commit bot

[stubs] Also handle properties of the JSBuiltinsObject in the fast case.

We can apply the shortcut used for data properties of the JSGlobalObject
to builtin properties as well. This mostly affects the custom properties
we use for the Math functions (i.e. rngstate for Math.random() and kMath
for sin, cos and friends).

Drive-by-fix: Also mark the internal builtin typed arrays properties
(rngstate, kMath and rempio2result) as READ_ONLY, as they should not be
touched after genesis.

R=yangguo@chromium.org

Review URL: https://codereview.chromium.org/1254143003

Cr-Commit-Position: refs/heads/master@{#29887}
parent 5dff4bdf
...@@ -1819,7 +1819,8 @@ Data* SetBuiltinTypedArray(Isolate* isolate, Handle<JSBuiltinsObject> builtins, ...@@ -1819,7 +1819,8 @@ Data* SetBuiltinTypedArray(Isolate* isolate, Handle<JSBuiltinsObject> builtins,
// Reset property cell type before (re)initializing. // Reset property cell type before (re)initializing.
JSBuiltinsObject::InvalidatePropertyCell(builtins, name_string); JSBuiltinsObject::InvalidatePropertyCell(builtins, name_string);
JSObject::SetOwnPropertyIgnoreAttributes(builtins, name_string, typed_array, JSObject::SetOwnPropertyIgnoreAttributes(builtins, name_string, typed_array,
DONT_DELETE).Assert(); FROZEN)
.Assert();
return data; return data;
} }
......
...@@ -437,8 +437,8 @@ RUNTIME_FUNCTION(Runtime_LoadGlobalViaContext) { ...@@ -437,8 +437,8 @@ RUNTIME_FUNCTION(Runtime_LoadGlobalViaContext) {
// Switch to fast mode only if there is a data property and it's not on // Switch to fast mode only if there is a data property and it's not on
// a hidden prototype. // a hidden prototype.
if (LookupIterator::DATA == it.state() && if (it.state() == LookupIterator::DATA &&
it.GetHolder<Object>()->IsJSGlobalObject()) { it.GetHolder<Object>().is_identical_to(global_object)) {
// Now update the cell in the script context. // Now update the cell in the script context.
Handle<PropertyCell> cell = it.GetPropertyCell(); Handle<PropertyCell> cell = it.GetPropertyCell();
script_context->set(slot, *cell); script_context->set(slot, *cell);
...@@ -469,10 +469,11 @@ Object* StoreGlobalViaContext(Isolate* isolate, int slot, Handle<Object> value, ...@@ -469,10 +469,11 @@ Object* StoreGlobalViaContext(Isolate* isolate, int slot, Handle<Object> value,
Handle<Name> name(scope_info->ContextSlotName(slot), isolate); Handle<Name> name(scope_info->ContextSlotName(slot), isolate);
Handle<GlobalObject> global_object(script_context->global_object(), isolate); Handle<GlobalObject> global_object(script_context->global_object(), isolate);
LookupIterator it(global_object, name, LookupIterator::HIDDEN); LookupIterator it(global_object, name, LookupIterator::HIDDEN);
// Switch to fast mode only if there is a data property and it's not on // Switch to fast mode only if there is a data property and it's not on
// a hidden prototype. // a hidden prototype.
if (LookupIterator::DATA == it.state() && if (it.state() == LookupIterator::DATA &&
it.GetHolder<Object>()->IsJSGlobalObject()) { it.GetHolder<Object>().is_identical_to(global_object)) {
// Now update cell in the script context. // Now update cell in the script context.
Handle<PropertyCell> cell = it.GetPropertyCell(); Handle<PropertyCell> cell = it.GetPropertyCell();
script_context->set(slot, *cell); script_context->set(slot, *cell);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment