Commit 0c4be22c authored by mstarzinger's avatar mstarzinger Committed by Commit bot

[arm64] Address TODO in CallConstructStub::Generate.

R=jacob.bramley@arm.com

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

Cr-Commit-Position: refs/heads/master@{#29773}
parent 5a556dfe
...@@ -2748,18 +2748,18 @@ void RegExpExecStub::Generate(MacroAssembler* masm) { ...@@ -2748,18 +2748,18 @@ void RegExpExecStub::Generate(MacroAssembler* masm) {
static void CallStubInRecordCallTarget(MacroAssembler* masm, CodeStub* stub, static void CallStubInRecordCallTarget(MacroAssembler* masm, CodeStub* stub,
Register argc, Register function, Register argc, Register function,
Register feedback_vector, Register feedback_vector, Register index,
Register index) { Register orig_construct) {
FrameScope scope(masm, StackFrame::INTERNAL); FrameScope scope(masm, StackFrame::INTERNAL);
// Number-of-arguments register must be smi-tagged to call out. // Number-of-arguments register must be smi-tagged to call out.
__ SmiTag(argc); __ SmiTag(argc);
__ Push(argc, function, feedback_vector, index); __ Push(argc, function, feedback_vector, index, orig_construct);
DCHECK(feedback_vector.Is(x2) && index.Is(x3)); DCHECK(feedback_vector.Is(x2) && index.Is(x3));
__ CallStub(stub); __ CallStub(stub);
__ Pop(index, feedback_vector, function, argc); __ Pop(orig_construct, index, feedback_vector, function, argc);
__ SmiUntag(argc); __ SmiUntag(argc);
} }
...@@ -2767,17 +2767,18 @@ static void CallStubInRecordCallTarget(MacroAssembler* masm, CodeStub* stub, ...@@ -2767,17 +2767,18 @@ static void CallStubInRecordCallTarget(MacroAssembler* masm, CodeStub* stub,
static void GenerateRecordCallTarget(MacroAssembler* masm, Register argc, static void GenerateRecordCallTarget(MacroAssembler* masm, Register argc,
Register function, Register function,
Register feedback_vector, Register index, Register feedback_vector, Register index,
Register scratch1, Register scratch2, Register orig_construct, Register scratch1,
Register scratch3) { Register scratch2, Register scratch3) {
ASM_LOCATION("GenerateRecordCallTarget"); ASM_LOCATION("GenerateRecordCallTarget");
DCHECK(!AreAliased(scratch1, scratch2, scratch3, argc, function, DCHECK(!AreAliased(scratch1, scratch2, scratch3, argc, function,
feedback_vector, index)); feedback_vector, index, orig_construct));
// Cache the called function in a feedback vector slot. Cache states are // Cache the called function in a feedback vector slot. Cache states are
// uninitialized, monomorphic (indicated by a JSFunction), and megamorphic. // uninitialized, monomorphic (indicated by a JSFunction), and megamorphic.
// argc : number of arguments to the construct function // argc : number of arguments to the construct function
// function : the function to call // function : the function to call
// feedback_vector : the feedback vector // feedback_vector : the feedback vector
// index : slot in feedback vector (smi) // index : slot in feedback vector (smi)
// orig_construct : original constructor
Label initialize, done, miss, megamorphic, not_array_function; Label initialize, done, miss, megamorphic, not_array_function;
DCHECK_EQ(*TypeFeedbackVector::MegamorphicSentinel(masm->isolate()), DCHECK_EQ(*TypeFeedbackVector::MegamorphicSentinel(masm->isolate()),
...@@ -2856,7 +2857,7 @@ static void GenerateRecordCallTarget(MacroAssembler* masm, Register argc, ...@@ -2856,7 +2857,7 @@ static void GenerateRecordCallTarget(MacroAssembler* masm, Register argc,
// slot. // slot.
CreateAllocationSiteStub create_stub(masm->isolate()); CreateAllocationSiteStub create_stub(masm->isolate());
CallStubInRecordCallTarget(masm, &create_stub, argc, function, CallStubInRecordCallTarget(masm, &create_stub, argc, function,
feedback_vector, index); feedback_vector, index, orig_construct);
__ B(&done); __ B(&done);
__ Bind(&not_array_function); __ Bind(&not_array_function);
...@@ -2864,7 +2865,7 @@ static void GenerateRecordCallTarget(MacroAssembler* masm, Register argc, ...@@ -2864,7 +2865,7 @@ static void GenerateRecordCallTarget(MacroAssembler* masm, Register argc,
CreateWeakCellStub create_stub(masm->isolate()); CreateWeakCellStub create_stub(masm->isolate());
CallStubInRecordCallTarget(masm, &create_stub, argc, function, CallStubInRecordCallTarget(masm, &create_stub, argc, function,
feedback_vector, index); feedback_vector, index, orig_construct);
__ Bind(&done); __ Bind(&done);
} }
...@@ -3004,14 +3005,7 @@ void CallConstructStub::Generate(MacroAssembler* masm) { ...@@ -3004,14 +3005,7 @@ void CallConstructStub::Generate(MacroAssembler* masm) {
&slow); &slow);
if (RecordCallTarget()) { if (RecordCallTarget()) {
if (IsSuperConstructorCall()) { GenerateRecordCallTarget(masm, x0, function, x2, x3, x4, x5, x11, x12);
__ Push(x4);
}
// TODO(mstarzinger): Consider tweaking target recording to avoid push/pop.
GenerateRecordCallTarget(masm, x0, function, x2, x3, x4, x5, x11);
if (IsSuperConstructorCall()) {
__ Pop(x4);
}
__ Add(x5, x2, Operand::UntagSmiAndScale(x3, kPointerSizeLog2)); __ Add(x5, x2, Operand::UntagSmiAndScale(x3, kPointerSizeLog2));
if (FLAG_pretenuring_call_new) { if (FLAG_pretenuring_call_new) {
......
...@@ -907,6 +907,25 @@ void MacroAssembler::Pop(const CPURegister& dst0, const CPURegister& dst1, ...@@ -907,6 +907,25 @@ void MacroAssembler::Pop(const CPURegister& dst0, const CPURegister& dst1,
} }
void MacroAssembler::Pop(const CPURegister& dst0, const CPURegister& dst1,
const CPURegister& dst2, const CPURegister& dst3,
const CPURegister& dst4, const CPURegister& dst5,
const CPURegister& dst6, const CPURegister& dst7) {
// It is not valid to pop into the same register more than once in one
// instruction, not even into the zero register.
DCHECK(!AreAliased(dst0, dst1, dst2, dst3, dst4, dst5, dst6, dst7));
DCHECK(AreSameSizeAndType(dst0, dst1, dst2, dst3, dst4, dst5, dst6, dst7));
DCHECK(dst0.IsValid());
int count = 5 + dst5.IsValid() + dst6.IsValid() + dst7.IsValid();
int size = dst0.SizeInBytes();
PopHelper(4, size, dst0, dst1, dst2, dst3);
PopHelper(count - 4, size, dst4, dst5, dst6, dst7);
PopPostamble(count, size);
}
void MacroAssembler::Push(const Register& src0, const FPRegister& src1) { void MacroAssembler::Push(const Register& src0, const FPRegister& src1) {
int size = src0.SizeInBytes() + src1.SizeInBytes(); int size = src0.SizeInBytes() + src1.SizeInBytes();
......
...@@ -569,6 +569,10 @@ class MacroAssembler : public Assembler { ...@@ -569,6 +569,10 @@ class MacroAssembler : public Assembler {
const CPURegister& src6 = NoReg, const CPURegister& src7 = NoReg); const CPURegister& src6 = NoReg, const CPURegister& src7 = NoReg);
void Pop(const CPURegister& dst0, const CPURegister& dst1 = NoReg, void Pop(const CPURegister& dst0, const CPURegister& dst1 = NoReg,
const CPURegister& dst2 = NoReg, const CPURegister& dst3 = NoReg); const CPURegister& dst2 = NoReg, const CPURegister& dst3 = NoReg);
void Pop(const CPURegister& dst0, const CPURegister& dst1,
const CPURegister& dst2, const CPURegister& dst3,
const CPURegister& dst4, const CPURegister& dst5 = NoReg,
const CPURegister& dst6 = NoReg, const CPURegister& dst7 = NoReg);
void Push(const Register& src0, const FPRegister& src1); void Push(const Register& src0, const FPRegister& src1);
// Alternative forms of Push and Pop, taking a RegList or CPURegList that // Alternative forms of Push and Pop, taking a RegList or CPURegList that
......
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