| Index: src/s390/code-stubs-s390.cc
|
| diff --git a/src/s390/code-stubs-s390.cc b/src/s390/code-stubs-s390.cc
|
| index 53e3fd13976ec3dbc63a54185d99c2898bba42cc..03e1d98a03abf5c3de5bcc96fc5431035b7c02f5 100644
|
| --- a/src/s390/code-stubs-s390.cc
|
| +++ b/src/s390/code-stubs-s390.cc
|
| @@ -3471,124 +3471,6 @@ void InternalArrayConstructorStub::Generate(MacroAssembler* masm) {
|
| GenerateCase(masm, FAST_ELEMENTS);
|
| }
|
|
|
| -void FastNewObjectStub::Generate(MacroAssembler* masm) {
|
| - // ----------- S t a t e -------------
|
| - // -- r3 : target
|
| - // -- r5 : new target
|
| - // -- cp : context
|
| - // -- lr : return address
|
| - // -----------------------------------
|
| - __ AssertFunction(r3);
|
| - __ AssertReceiver(r5);
|
| -
|
| - // Verify that the new target is a JSFunction.
|
| - Label new_object;
|
| - __ CompareObjectType(r5, r4, r4, JS_FUNCTION_TYPE);
|
| - __ bne(&new_object);
|
| -
|
| - // Load the initial map and verify that it's in fact a map.
|
| - __ LoadP(r4, FieldMemOperand(r5, JSFunction::kPrototypeOrInitialMapOffset));
|
| - __ JumpIfSmi(r4, &new_object);
|
| - __ CompareObjectType(r4, r2, r2, MAP_TYPE);
|
| - __ bne(&new_object);
|
| -
|
| - // Fall back to runtime if the target differs from the new target's
|
| - // initial map constructor.
|
| - __ LoadP(r2, FieldMemOperand(r4, Map::kConstructorOrBackPointerOffset));
|
| - __ CmpP(r2, r3);
|
| - __ bne(&new_object);
|
| -
|
| - // Allocate the JSObject on the heap.
|
| - Label allocate, done_allocate;
|
| - __ LoadlB(r6, FieldMemOperand(r4, Map::kInstanceSizeOffset));
|
| - __ Allocate(r6, r2, r7, r8, &allocate, SIZE_IN_WORDS);
|
| - __ bind(&done_allocate);
|
| -
|
| - // Initialize the JSObject fields.
|
| - __ StoreP(r4, FieldMemOperand(r2, JSObject::kMapOffset));
|
| - __ LoadRoot(r5, Heap::kEmptyFixedArrayRootIndex);
|
| - __ StoreP(r5, FieldMemOperand(r2, JSObject::kPropertiesOffset));
|
| - __ StoreP(r5, FieldMemOperand(r2, JSObject::kElementsOffset));
|
| - STATIC_ASSERT(JSObject::kHeaderSize == 3 * kPointerSize);
|
| - __ AddP(r3, r2, Operand(JSObject::kHeaderSize - kHeapObjectTag));
|
| -
|
| - // ----------- S t a t e -------------
|
| - // -- r2 : result (tagged)
|
| - // -- r3 : result fields (untagged)
|
| - // -- r7 : result end (untagged)
|
| - // -- r4 : initial map
|
| - // -- cp : context
|
| - // -- lr : return address
|
| - // -----------------------------------
|
| -
|
| - // Perform in-object slack tracking if requested.
|
| - Label slack_tracking;
|
| - STATIC_ASSERT(Map::kNoSlackTracking == 0);
|
| - __ LoadRoot(r8, Heap::kUndefinedValueRootIndex);
|
| - __ LoadlW(r5, FieldMemOperand(r4, Map::kBitField3Offset));
|
| - __ DecodeField<Map::ConstructionCounter>(r9, r5);
|
| - __ LoadAndTestP(r9, r9);
|
| - __ bne(&slack_tracking);
|
| - {
|
| - // Initialize all in-object fields with undefined.
|
| - __ InitializeFieldsWithFiller(r3, r7, r8);
|
| -
|
| - __ Ret();
|
| - }
|
| - __ bind(&slack_tracking);
|
| - {
|
| - // Decrease generous allocation count.
|
| - STATIC_ASSERT(Map::ConstructionCounter::kNext == 32);
|
| - __ Add32(r5, r5, Operand(-(1 << Map::ConstructionCounter::kShift)));
|
| - __ StoreW(r5, FieldMemOperand(r4, Map::kBitField3Offset));
|
| -
|
| - // Initialize the in-object fields with undefined.
|
| - __ LoadlB(r6, FieldMemOperand(r4, Map::kUnusedPropertyFieldsOffset));
|
| - __ ShiftLeftP(r6, r6, Operand(kPointerSizeLog2));
|
| - __ SubP(r6, r7, r6);
|
| - __ InitializeFieldsWithFiller(r3, r6, r8);
|
| -
|
| - // Initialize the remaining (reserved) fields with one pointer filler map.
|
| - __ LoadRoot(r8, Heap::kOnePointerFillerMapRootIndex);
|
| - __ InitializeFieldsWithFiller(r3, r7, r8);
|
| -
|
| - // Check if we can finalize the instance size.
|
| - __ CmpP(r9, Operand(Map::kSlackTrackingCounterEnd));
|
| - __ Ret(ne);
|
| -
|
| - // Finalize the instance size.
|
| - {
|
| - FrameAndConstantPoolScope scope(masm, StackFrame::INTERNAL);
|
| - __ Push(r2, r4);
|
| - __ CallRuntime(Runtime::kFinalizeInstanceSize);
|
| - __ Pop(r2);
|
| - }
|
| - __ Ret();
|
| - }
|
| -
|
| - // Fall back to %AllocateInNewSpace.
|
| - __ bind(&allocate);
|
| - {
|
| - FrameAndConstantPoolScope scope(masm, StackFrame::INTERNAL);
|
| - STATIC_ASSERT(kSmiTag == 0);
|
| - __ ShiftLeftP(r6, r6,
|
| - Operand(kPointerSizeLog2 + kSmiTagSize + kSmiShiftSize));
|
| - __ Push(r4, r6);
|
| - __ CallRuntime(Runtime::kAllocateInNewSpace);
|
| - __ Pop(r4);
|
| - }
|
| - __ LoadlB(r7, FieldMemOperand(r4, Map::kInstanceSizeOffset));
|
| - __ ShiftLeftP(r7, r7, Operand(kPointerSizeLog2));
|
| - __ AddP(r7, r2, r7);
|
| - __ SubP(r7, r7, Operand(kHeapObjectTag));
|
| - __ b(&done_allocate);
|
| -
|
| - // Fall back to %NewObject.
|
| - __ bind(&new_object);
|
| - __ Push(r3, r5);
|
| - __ TailCallRuntime(Runtime::kNewObject);
|
| -}
|
| -
|
| void FastNewRestParameterStub::Generate(MacroAssembler* masm) {
|
| // ----------- S t a t e -------------
|
| // -- r3 : function
|
|
|