Commit 8b781ecc authored by mbrandy's avatar mbrandy Committed by Commit bot

PPC: [builtins] Pass correct number of arguments after adapting arguments.

Port fbad6366

Original commit message:
    The call protocol requires that the register dedicated to the number of
    actual arguments (i.e. rax on x64) always contains the actual arguments.
    That means after adapting arguments it should match the number of
    expected arguments.  But currently we pass some semi-random value
    (usually some stack address) after adapting arguments.

    It looks like this is currently not observable anywhere, because our
    builtins and functions either don't look at the number of arguments and
    just make hard coded (unchecked) assumptions, or are marked as "don't
    adapt arguments", which bypasses the broken code in the trampoline for
    arguments adaption.  Nevertheless this should be fixed.

R=bmeurer@chromium.org, jyan@ca.ibm.com, dstence@us.ibm.com, joransiu@ca.ibm.com
BUG=

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

Cr-Commit-Position: refs/heads/master@{#30480}
parent 445747ad
...@@ -1797,7 +1797,7 @@ void Builtins::Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm) { ...@@ -1797,7 +1797,7 @@ void Builtins::Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm) {
__ bind(&enough); __ bind(&enough);
EnterArgumentsAdaptorFrame(masm); EnterArgumentsAdaptorFrame(masm);
// Calculate copy start address into r3 and copy end address into r5. // Calculate copy start address into r3 and copy end address into r6.
// r3: actual number of arguments as a smi // r3: actual number of arguments as a smi
// r4: function // r4: function
// r5: expected number of arguments // r5: expected number of arguments
...@@ -1806,20 +1806,21 @@ void Builtins::Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm) { ...@@ -1806,20 +1806,21 @@ void Builtins::Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm) {
__ add(r3, r3, fp); __ add(r3, r3, fp);
// adjust for return address and receiver // adjust for return address and receiver
__ addi(r3, r3, Operand(2 * kPointerSize)); __ addi(r3, r3, Operand(2 * kPointerSize));
__ ShiftLeftImm(r5, r5, Operand(kPointerSizeLog2)); __ ShiftLeftImm(r6, r5, Operand(kPointerSizeLog2));
__ sub(r5, r3, r5); __ sub(r6, r3, r6);
// Copy the arguments (including the receiver) to the new stack frame. // Copy the arguments (including the receiver) to the new stack frame.
// r3: copy start address // r3: copy start address
// r4: function // r4: function
// r5: copy end address // r5: expected number of arguments
// r6: copy end address
// ip: code entry to call // ip: code entry to call
Label copy; Label copy;
__ bind(&copy); __ bind(&copy);
__ LoadP(r0, MemOperand(r3, 0)); __ LoadP(r0, MemOperand(r3, 0));
__ push(r0); __ push(r0);
__ cmp(r3, r5); // Compare before moving to next argument. __ cmp(r3, r6); // Compare before moving to next argument.
__ subi(r3, r3, Operand(kPointerSize)); __ subi(r3, r3, Operand(kPointerSize));
__ bne(&copy); __ bne(&copy);
...@@ -1889,21 +1890,24 @@ void Builtins::Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm) { ...@@ -1889,21 +1890,24 @@ void Builtins::Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm) {
// r5: expected number of arguments // r5: expected number of arguments
// ip: code entry to call // ip: code entry to call
__ LoadRoot(r0, Heap::kUndefinedValueRootIndex); __ LoadRoot(r0, Heap::kUndefinedValueRootIndex);
__ ShiftLeftImm(r5, r5, Operand(kPointerSizeLog2)); __ ShiftLeftImm(r6, r5, Operand(kPointerSizeLog2));
__ sub(r5, fp, r5); __ sub(r6, fp, r6);
// Adjust for frame. // Adjust for frame.
__ subi(r5, r5, Operand(StandardFrameConstants::kFixedFrameSizeFromFp + __ subi(r6, r6, Operand(StandardFrameConstants::kFixedFrameSizeFromFp +
2 * kPointerSize)); 2 * kPointerSize));
Label fill; Label fill;
__ bind(&fill); __ bind(&fill);
__ push(r0); __ push(r0);
__ cmp(sp, r5); __ cmp(sp, r6);
__ bne(&fill); __ bne(&fill);
} }
// Call the entry point. // Call the entry point.
__ bind(&invoke); __ bind(&invoke);
__ mr(r3, r5);
// r3 : expected number of arguments
// r4 : function (passed through to callee)
__ CallJSEntry(ip); __ CallJSEntry(ip);
// Store offset of return address for deoptimizer. // Store offset of return address for deoptimizer.
......
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