Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(566)

Side by Side Diff: src/ia32/builtins-ia32.cc

Issue 1413033006: Reland "[es6] Better support for built-ins subclassing." (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: We don't need TypedArray map smashing anymore Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/heap/heap.cc ('k') | src/mips/builtins-mips.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2012 the V8 project authors. All rights reserved. 1 // Copyright 2012 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #if V8_TARGET_ARCH_IA32 5 #if V8_TARGET_ARCH_IA32
6 6
7 #include "src/code-factory.h" 7 #include "src/code-factory.h"
8 #include "src/codegen.h" 8 #include "src/codegen.h"
9 #include "src/deoptimizer.h" 9 #include "src/deoptimizer.h"
10 #include "src/full-codegen/full-codegen.h" 10 #include "src/full-codegen/full-codegen.h"
(...skipping 262 matching lines...) Expand 10 before | Expand all | Expand 10 after
273 273
274 // Allocate the new receiver object using the runtime call. 274 // Allocate the new receiver object using the runtime call.
275 // edx: original constructor 275 // edx: original constructor
276 __ bind(&rt_call); 276 __ bind(&rt_call);
277 int offset = kPointerSize; 277 int offset = kPointerSize;
278 278
279 // Must restore esi (context) and edi (constructor) before calling 279 // Must restore esi (context) and edi (constructor) before calling
280 // runtime. 280 // runtime.
281 __ mov(esi, Operand(ebp, StandardFrameConstants::kContextOffset)); 281 __ mov(esi, Operand(ebp, StandardFrameConstants::kContextOffset));
282 __ mov(edi, Operand(esp, offset)); 282 __ mov(edi, Operand(esp, offset));
283 __ push(edi); // argument 2/1: constructor function 283 __ push(edi); // constructor function
284 __ push(edx); // argument 3/2: original constructor 284 __ push(edx); // original constructor
285 __ CallRuntime(Runtime::kNewObject, 2); 285 __ CallRuntime(Runtime::kNewObject, 2);
286 __ mov(ebx, eax); // store result in ebx 286 __ mov(ebx, eax); // store result in ebx
287 287
288 // New object allocated. 288 // New object allocated.
289 // ebx: newly allocated object 289 // ebx: newly allocated object
290 __ bind(&allocated); 290 __ bind(&allocated);
291 291
292 // Restore the parameters. 292 // Restore the parameters.
293 __ pop(edx); // new.target 293 __ pop(edx); // new.target
294 __ pop(edi); // Constructor function. 294 __ pop(edi); // Constructor function.
(...skipping 1061 matching lines...) Expand 10 before | Expand all | Expand 10 after
1356 __ TailCallRuntime(Runtime::kSymbolDescriptiveString, 1, 1); 1356 __ TailCallRuntime(Runtime::kSymbolDescriptiveString, 1, 1);
1357 } 1357 }
1358 } 1358 }
1359 1359
1360 1360
1361 // static 1361 // static
1362 void Builtins::Generate_StringConstructor_ConstructStub(MacroAssembler* masm) { 1362 void Builtins::Generate_StringConstructor_ConstructStub(MacroAssembler* masm) {
1363 // ----------- S t a t e ------------- 1363 // ----------- S t a t e -------------
1364 // -- eax : number of arguments 1364 // -- eax : number of arguments
1365 // -- edi : constructor function 1365 // -- edi : constructor function
1366 // -- edx : original constructor
1366 // -- esp[0] : return address 1367 // -- esp[0] : return address
1367 // -- esp[(argc - n) * 4] : arg[n] (zero-based) 1368 // -- esp[(argc - n) * 4] : arg[n] (zero-based)
1368 // -- esp[(argc + 1) * 4] : receiver 1369 // -- esp[(argc + 1) * 4] : receiver
1369 // ----------------------------------- 1370 // -----------------------------------
1370 1371
1371 // 1. Load the first argument into ebx and get rid of the rest (including the 1372 // 1. Load the first argument into ebx and get rid of the rest (including the
1372 // receiver). 1373 // receiver).
1373 { 1374 {
1374 Label no_arguments, done; 1375 Label no_arguments, done;
1375 __ test(eax, eax); 1376 __ test(eax, eax);
1376 __ j(zero, &no_arguments, Label::kNear); 1377 __ j(zero, &no_arguments, Label::kNear);
1377 __ mov(ebx, Operand(esp, eax, times_pointer_size, 0)); 1378 __ mov(ebx, Operand(esp, eax, times_pointer_size, 0));
1378 __ jmp(&done, Label::kNear); 1379 __ jmp(&done, Label::kNear);
1379 __ bind(&no_arguments); 1380 __ bind(&no_arguments);
1380 __ LoadRoot(ebx, Heap::kempty_stringRootIndex); 1381 __ LoadRoot(ebx, Heap::kempty_stringRootIndex);
1381 __ bind(&done); 1382 __ bind(&done);
1382 __ PopReturnAddressTo(ecx); 1383 __ PopReturnAddressTo(ecx);
1383 __ lea(esp, Operand(esp, eax, times_pointer_size, kPointerSize)); 1384 __ lea(esp, Operand(esp, eax, times_pointer_size, kPointerSize));
1384 __ PushReturnAddressFrom(ecx); 1385 __ PushReturnAddressFrom(ecx);
1385 } 1386 }
1386 1387
1387 // 2. Make sure ebx is a string. 1388 // 2. Make sure ebx is a string.
1388 { 1389 {
1389 Label convert, done_convert; 1390 Label convert, done_convert;
1390 __ JumpIfSmi(ebx, &convert, Label::kNear); 1391 __ JumpIfSmi(ebx, &convert, Label::kNear);
1391 __ CmpObjectType(ebx, FIRST_NONSTRING_TYPE, edx); 1392 __ CmpObjectType(ebx, FIRST_NONSTRING_TYPE, ecx);
1392 __ j(below, &done_convert); 1393 __ j(below, &done_convert);
1393 __ bind(&convert); 1394 __ bind(&convert);
1394 { 1395 {
1395 FrameScope scope(masm, StackFrame::INTERNAL); 1396 FrameScope scope(masm, StackFrame::INTERNAL);
1396 ToStringStub stub(masm->isolate()); 1397 ToStringStub stub(masm->isolate());
1397 __ Push(edi); 1398 __ Push(edi);
1399 __ Push(edx);
1398 __ Move(eax, ebx); 1400 __ Move(eax, ebx);
1399 __ CallStub(&stub); 1401 __ CallStub(&stub);
1400 __ Move(ebx, eax); 1402 __ Move(ebx, eax);
1403 __ Pop(edx);
1401 __ Pop(edi); 1404 __ Pop(edi);
1402 } 1405 }
1403 __ bind(&done_convert); 1406 __ bind(&done_convert);
1404 } 1407 }
1405 1408
1406 // 3. Allocate a JSValue wrapper for the string. 1409 // 3. Allocate a JSValue wrapper for the string.
1407 { 1410 {
1408 // ----------- S t a t e ------------- 1411 // ----------- S t a t e -------------
1409 // -- ebx : the first argument 1412 // -- ebx : the first argument
1410 // -- edi : constructor function 1413 // -- edi : constructor function
1414 // -- edx : original constructor
1411 // ----------------------------------- 1415 // -----------------------------------
1412 1416
1413 Label allocate, done_allocate; 1417 Label allocate, done_allocate, rt_call;
1418
1419 // Fall back to runtime if the original constructor and constructor differ.
1420 __ cmp(edx, edi);
1421 __ j(not_equal, &rt_call);
1422
1414 __ Allocate(JSValue::kSize, eax, ecx, no_reg, &allocate, TAG_OBJECT); 1423 __ Allocate(JSValue::kSize, eax, ecx, no_reg, &allocate, TAG_OBJECT);
1415 __ bind(&done_allocate); 1424 __ bind(&done_allocate);
1416 1425
1417 // Initialize the JSValue in eax. 1426 // Initialize the JSValue in eax.
1418 __ LoadGlobalFunctionInitialMap(edi, ecx); 1427 __ LoadGlobalFunctionInitialMap(edi, ecx);
1419 __ mov(FieldOperand(eax, HeapObject::kMapOffset), ecx); 1428 __ mov(FieldOperand(eax, HeapObject::kMapOffset), ecx);
1420 __ mov(FieldOperand(eax, JSObject::kPropertiesOffset), 1429 __ mov(FieldOperand(eax, JSObject::kPropertiesOffset),
1421 masm->isolate()->factory()->empty_fixed_array()); 1430 masm->isolate()->factory()->empty_fixed_array());
1422 __ mov(FieldOperand(eax, JSObject::kElementsOffset), 1431 __ mov(FieldOperand(eax, JSObject::kElementsOffset),
1423 masm->isolate()->factory()->empty_fixed_array()); 1432 masm->isolate()->factory()->empty_fixed_array());
1424 __ mov(FieldOperand(eax, JSValue::kValueOffset), ebx); 1433 __ mov(FieldOperand(eax, JSValue::kValueOffset), ebx);
1425 STATIC_ASSERT(JSValue::kSize == 4 * kPointerSize); 1434 STATIC_ASSERT(JSValue::kSize == 4 * kPointerSize);
1426 __ Ret(); 1435 __ Ret();
1427 1436
1428 // Fallback to the runtime to allocate in new space. 1437 // Fallback to the runtime to allocate in new space.
1429 __ bind(&allocate); 1438 __ bind(&allocate);
1430 { 1439 {
1431 FrameScope scope(masm, StackFrame::INTERNAL); 1440 FrameScope scope(masm, StackFrame::INTERNAL);
1432 __ Push(ebx); 1441 __ Push(ebx);
1433 __ Push(edi); 1442 __ Push(edi);
1434 __ Push(Smi::FromInt(JSValue::kSize)); 1443 __ Push(Smi::FromInt(JSValue::kSize));
1435 __ CallRuntime(Runtime::kAllocateInNewSpace, 1); 1444 __ CallRuntime(Runtime::kAllocateInNewSpace, 1);
1436 __ Pop(edi); 1445 __ Pop(edi);
1437 __ Pop(ebx); 1446 __ Pop(ebx);
1438 } 1447 }
1439 __ jmp(&done_allocate); 1448 __ jmp(&done_allocate);
1449
1450 // Fallback to the runtime to create new object.
1451 __ bind(&rt_call);
1452 {
1453 FrameScope scope(masm, StackFrame::INTERNAL);
1454 __ Push(ebx);
1455 __ Push(edi);
1456 __ Push(edi); // constructor function
1457 __ Push(edx); // original constructor
1458 __ CallRuntime(Runtime::kNewObject, 2);
1459 __ Pop(edi);
1460 __ Pop(ebx);
1461 }
1462 __ mov(FieldOperand(eax, JSValue::kValueOffset), ebx);
1463 __ Ret();
1440 } 1464 }
1441 } 1465 }
1442 1466
1443 1467
1444 static void ArgumentsAdaptorStackCheck(MacroAssembler* masm, 1468 static void ArgumentsAdaptorStackCheck(MacroAssembler* masm,
1445 Label* stack_overflow) { 1469 Label* stack_overflow) {
1446 // ----------- S t a t e ------------- 1470 // ----------- S t a t e -------------
1447 // -- eax : actual number of arguments 1471 // -- eax : actual number of arguments
1448 // -- ebx : expected number of arguments 1472 // -- ebx : expected number of arguments
1449 // -- edi : function (passed through to callee) 1473 // -- edi : function (passed through to callee)
(...skipping 450 matching lines...) Expand 10 before | Expand all | Expand 10 after
1900 1924
1901 __ bind(&ok); 1925 __ bind(&ok);
1902 __ ret(0); 1926 __ ret(0);
1903 } 1927 }
1904 1928
1905 #undef __ 1929 #undef __
1906 } // namespace internal 1930 } // namespace internal
1907 } // namespace v8 1931 } // namespace v8
1908 1932
1909 #endif // V8_TARGET_ARCH_IA32 1933 #endif // V8_TARGET_ARCH_IA32
OLDNEW
« no previous file with comments | « src/heap/heap.cc ('k') | src/mips/builtins-mips.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698