PPC/s390: Store OSR'd optimized code on the native context.

Port 378b6b22fb

Original Commit Message:

    Since we OSR code rarely, it makes sense to store it and look for
    it on the native context rather than the SharedFunctionInfo.
    This makes the OptimizedCodeMap data structure more space efficient,
    as it doesn't have to store an ast ID for the OSR entry point.

R=mvstanton@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
BUG=
LOG=N

Review-Url: https://codereview.chromium.org/2557113002
Cr-Commit-Position: refs/heads/master@{#41562}
This commit is contained in:
bjaideep 2016-12-07 10:55:25 -08:00 committed by Commit bot
parent 0d29250547
commit 3bc53ad765
2 changed files with 0 additions and 14 deletions

View File

@ -1390,13 +1390,6 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
__ LoadP(temp, FieldMemOperand(temp, WeakCell::kValueOffset)); __ LoadP(temp, FieldMemOperand(temp, WeakCell::kValueOffset));
__ cmp(temp, native_context); __ cmp(temp, native_context);
__ bne(&loop_bottom); __ bne(&loop_bottom);
// OSR id set to none?
__ LoadP(temp,
FieldMemOperand(array_pointer,
SharedFunctionInfo::kOffsetToPreviousOsrAstId));
const int bailout_id = BailoutId::None().ToInt();
__ CmpSmiLiteral(temp, Smi::FromInt(bailout_id), r0);
__ bne(&loop_bottom);
// Literals available? // Literals available?
__ LoadP(temp, __ LoadP(temp,
FieldMemOperand(array_pointer, FieldMemOperand(array_pointer,

View File

@ -1395,13 +1395,6 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
__ LoadP(temp, FieldMemOperand(temp, WeakCell::kValueOffset)); __ LoadP(temp, FieldMemOperand(temp, WeakCell::kValueOffset));
__ CmpP(temp, native_context); __ CmpP(temp, native_context);
__ bne(&loop_bottom, Label::kNear); __ bne(&loop_bottom, Label::kNear);
// OSR id set to none?
__ LoadP(temp,
FieldMemOperand(array_pointer,
SharedFunctionInfo::kOffsetToPreviousOsrAstId));
const int bailout_id = BailoutId::None().ToInt();
__ CmpSmiLiteral(temp, Smi::FromInt(bailout_id), r0);
__ bne(&loop_bottom, Label::kNear);
// Literals available? // Literals available?
__ LoadP(temp, __ LoadP(temp,
FieldMemOperand(array_pointer, FieldMemOperand(array_pointer,