OLD | NEW |
1 // Copyright 2009 the V8 project authors. All rights reserved. | 1 // Copyright 2010 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
11 // with the distribution. | 11 // with the distribution. |
(...skipping 1335 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1347 return GetCode(CALLBACKS, name); | 1347 return GetCode(CALLBACKS, name); |
1348 } | 1348 } |
1349 | 1349 |
1350 | 1350 |
1351 Object* StoreStubCompiler::CompileStoreCallback(JSObject* object, | 1351 Object* StoreStubCompiler::CompileStoreCallback(JSObject* object, |
1352 AccessorInfo* callback, | 1352 AccessorInfo* callback, |
1353 String* name) { | 1353 String* name) { |
1354 // ----------- S t a t e ------------- | 1354 // ----------- S t a t e ------------- |
1355 // -- rax : value | 1355 // -- rax : value |
1356 // -- rcx : name | 1356 // -- rcx : name |
| 1357 // -- rdx : receiver |
1357 // -- rsp[0] : return address | 1358 // -- rsp[0] : return address |
1358 // -- rsp[8] : receiver | |
1359 // ----------------------------------- | 1359 // ----------------------------------- |
1360 Label miss; | 1360 Label miss; |
1361 | 1361 |
1362 // Get the object from the stack. | |
1363 __ movq(rbx, Operand(rsp, 1 * kPointerSize)); | |
1364 | |
1365 // Check that the object isn't a smi. | 1362 // Check that the object isn't a smi. |
1366 __ JumpIfSmi(rbx, &miss); | 1363 __ JumpIfSmi(rdx, &miss); |
1367 | 1364 |
1368 // Check that the map of the object hasn't changed. | 1365 // Check that the map of the object hasn't changed. |
1369 __ Cmp(FieldOperand(rbx, HeapObject::kMapOffset), | 1366 __ Cmp(FieldOperand(rdx, HeapObject::kMapOffset), |
1370 Handle<Map>(object->map())); | 1367 Handle<Map>(object->map())); |
1371 __ j(not_equal, &miss); | 1368 __ j(not_equal, &miss); |
1372 | 1369 |
1373 // Perform global security token check if needed. | 1370 // Perform global security token check if needed. |
1374 if (object->IsJSGlobalProxy()) { | 1371 if (object->IsJSGlobalProxy()) { |
1375 __ CheckAccessGlobalProxy(rbx, rdx, &miss); | 1372 __ CheckAccessGlobalProxy(rdx, rbx, &miss); |
1376 } | 1373 } |
1377 | 1374 |
1378 // Stub never generated for non-global objects that require access | 1375 // Stub never generated for non-global objects that require access |
1379 // checks. | 1376 // checks. |
1380 ASSERT(object->IsJSGlobalProxy() || !object->IsAccessCheckNeeded()); | 1377 ASSERT(object->IsJSGlobalProxy() || !object->IsAccessCheckNeeded()); |
1381 | 1378 |
1382 __ pop(rbx); // remove the return address | 1379 __ pop(rbx); // remove the return address |
1383 __ push(Operand(rsp, 0)); // receiver | 1380 __ push(rdx); // receiver |
1384 __ Push(Handle<AccessorInfo>(callback)); // callback info | 1381 __ Push(Handle<AccessorInfo>(callback)); // callback info |
1385 __ push(rcx); // name | 1382 __ push(rcx); // name |
1386 __ push(rax); // value | 1383 __ push(rax); // value |
1387 __ push(rbx); // restore return address | 1384 __ push(rbx); // restore return address |
1388 | 1385 |
1389 // Do tail-call to the runtime system. | 1386 // Do tail-call to the runtime system. |
1390 ExternalReference store_callback_property = | 1387 ExternalReference store_callback_property = |
1391 ExternalReference(IC_Utility(IC::kStoreCallbackProperty)); | 1388 ExternalReference(IC_Utility(IC::kStoreCallbackProperty)); |
1392 __ TailCallRuntime(store_callback_property, 4, 1); | 1389 __ TailCallRuntime(store_callback_property, 4, 1); |
1393 | 1390 |
1394 // Handle store cache miss. | 1391 // Handle store cache miss. |
1395 __ bind(&miss); | 1392 __ bind(&miss); |
1396 Handle<Code> ic(Builtins::builtin(Builtins::StoreIC_Miss)); | 1393 Handle<Code> ic(Builtins::builtin(Builtins::StoreIC_Miss)); |
1397 __ Jump(ic, RelocInfo::CODE_TARGET); | 1394 __ Jump(ic, RelocInfo::CODE_TARGET); |
1398 | 1395 |
1399 // Return the generated code. | 1396 // Return the generated code. |
1400 return GetCode(CALLBACKS, name); | 1397 return GetCode(CALLBACKS, name); |
1401 } | 1398 } |
1402 | 1399 |
1403 | 1400 |
1404 Object* StoreStubCompiler::CompileStoreField(JSObject* object, | 1401 Object* StoreStubCompiler::CompileStoreField(JSObject* object, |
1405 int index, | 1402 int index, |
1406 Map* transition, | 1403 Map* transition, |
1407 String* name) { | 1404 String* name) { |
1408 // ----------- S t a t e ------------- | 1405 // ----------- S t a t e ------------- |
1409 // -- rax : value | 1406 // -- rax : value |
1410 // -- rcx : name | 1407 // -- rcx : name |
| 1408 // -- rdx : receiver |
1411 // -- rsp[0] : return address | 1409 // -- rsp[0] : return address |
1412 // -- rsp[8] : receiver | |
1413 // ----------------------------------- | 1410 // ----------------------------------- |
1414 Label miss; | 1411 Label miss; |
1415 | 1412 |
1416 // Get the object from the stack. | |
1417 __ movq(rbx, Operand(rsp, 1 * kPointerSize)); | |
1418 | |
1419 // Generate store field code. Trashes the name register. | 1413 // Generate store field code. Trashes the name register. |
1420 GenerateStoreField(masm(), | 1414 GenerateStoreField(masm(), |
1421 Builtins::StoreIC_ExtendStorage, | 1415 Builtins::StoreIC_ExtendStorage, |
1422 object, | 1416 object, |
1423 index, | 1417 index, |
1424 transition, | 1418 transition, |
1425 rbx, rcx, rdx, | 1419 rdx, rcx, rbx, |
1426 &miss); | 1420 &miss); |
1427 | 1421 |
1428 // Handle store cache miss. | 1422 // Handle store cache miss. |
1429 __ bind(&miss); | 1423 __ bind(&miss); |
1430 __ Move(rcx, Handle<String>(name)); // restore name | 1424 __ Move(rcx, Handle<String>(name)); // restore name |
1431 Handle<Code> ic(Builtins::builtin(Builtins::StoreIC_Miss)); | 1425 Handle<Code> ic(Builtins::builtin(Builtins::StoreIC_Miss)); |
1432 __ Jump(ic, RelocInfo::CODE_TARGET); | 1426 __ Jump(ic, RelocInfo::CODE_TARGET); |
1433 | 1427 |
1434 // Return the generated code. | 1428 // Return the generated code. |
1435 return GetCode(transition == NULL ? FIELD : MAP_TRANSITION, name); | 1429 return GetCode(transition == NULL ? FIELD : MAP_TRANSITION, name); |
1436 } | 1430 } |
1437 | 1431 |
1438 | 1432 |
1439 Object* StoreStubCompiler::CompileStoreInterceptor(JSObject* receiver, | 1433 Object* StoreStubCompiler::CompileStoreInterceptor(JSObject* receiver, |
1440 String* name) { | 1434 String* name) { |
1441 // ----------- S t a t e ------------- | 1435 // ----------- S t a t e ------------- |
1442 // -- rax : value | 1436 // -- rax : value |
1443 // -- rcx : name | 1437 // -- rcx : name |
| 1438 // -- rdx : receiver |
1444 // -- rsp[0] : return address | 1439 // -- rsp[0] : return address |
1445 // -- rsp[8] : receiver | |
1446 // ----------------------------------- | 1440 // ----------------------------------- |
1447 Label miss; | 1441 Label miss; |
1448 | 1442 |
1449 // Get the object from the stack. | |
1450 __ movq(rbx, Operand(rsp, 1 * kPointerSize)); | |
1451 | |
1452 // Check that the object isn't a smi. | 1443 // Check that the object isn't a smi. |
1453 __ JumpIfSmi(rbx, &miss); | 1444 __ JumpIfSmi(rdx, &miss); |
1454 | 1445 |
1455 // Check that the map of the object hasn't changed. | 1446 // Check that the map of the object hasn't changed. |
1456 __ Cmp(FieldOperand(rbx, HeapObject::kMapOffset), | 1447 __ Cmp(FieldOperand(rdx, HeapObject::kMapOffset), |
1457 Handle<Map>(receiver->map())); | 1448 Handle<Map>(receiver->map())); |
1458 __ j(not_equal, &miss); | 1449 __ j(not_equal, &miss); |
1459 | 1450 |
1460 // Perform global security token check if needed. | 1451 // Perform global security token check if needed. |
1461 if (receiver->IsJSGlobalProxy()) { | 1452 if (receiver->IsJSGlobalProxy()) { |
1462 __ CheckAccessGlobalProxy(rbx, rdx, &miss); | 1453 __ CheckAccessGlobalProxy(rdx, rbx, &miss); |
1463 } | 1454 } |
1464 | 1455 |
1465 // Stub never generated for non-global objects that require access | 1456 // Stub never generated for non-global objects that require access |
1466 // checks. | 1457 // checks. |
1467 ASSERT(receiver->IsJSGlobalProxy() || !receiver->IsAccessCheckNeeded()); | 1458 ASSERT(receiver->IsJSGlobalProxy() || !receiver->IsAccessCheckNeeded()); |
1468 | 1459 |
1469 __ pop(rbx); // remove the return address | 1460 __ pop(rbx); // remove the return address |
1470 __ push(Operand(rsp, 0)); // receiver | 1461 __ push(rdx); // receiver |
1471 __ push(rcx); // name | 1462 __ push(rcx); // name |
1472 __ push(rax); // value | 1463 __ push(rax); // value |
1473 __ push(rbx); // restore return address | 1464 __ push(rbx); // restore return address |
1474 | 1465 |
1475 // Do tail-call to the runtime system. | 1466 // Do tail-call to the runtime system. |
1476 ExternalReference store_ic_property = | 1467 ExternalReference store_ic_property = |
1477 ExternalReference(IC_Utility(IC::kStoreInterceptorProperty)); | 1468 ExternalReference(IC_Utility(IC::kStoreInterceptorProperty)); |
1478 __ TailCallRuntime(store_ic_property, 3, 1); | 1469 __ TailCallRuntime(store_ic_property, 3, 1); |
1479 | 1470 |
1480 // Handle store cache miss. | 1471 // Handle store cache miss. |
1481 __ bind(&miss); | 1472 __ bind(&miss); |
1482 Handle<Code> ic(Builtins::builtin(Builtins::StoreIC_Miss)); | 1473 Handle<Code> ic(Builtins::builtin(Builtins::StoreIC_Miss)); |
1483 __ Jump(ic, RelocInfo::CODE_TARGET); | 1474 __ Jump(ic, RelocInfo::CODE_TARGET); |
1484 | 1475 |
1485 // Return the generated code. | 1476 // Return the generated code. |
1486 return GetCode(INTERCEPTOR, name); | 1477 return GetCode(INTERCEPTOR, name); |
1487 } | 1478 } |
1488 | 1479 |
1489 | 1480 |
1490 Object* StoreStubCompiler::CompileStoreGlobal(GlobalObject* object, | 1481 Object* StoreStubCompiler::CompileStoreGlobal(GlobalObject* object, |
1491 JSGlobalPropertyCell* cell, | 1482 JSGlobalPropertyCell* cell, |
1492 String* name) { | 1483 String* name) { |
1493 // ----------- S t a t e ------------- | 1484 // ----------- S t a t e ------------- |
1494 // -- rax : value | 1485 // -- rax : value |
1495 // -- rcx : name | 1486 // -- rcx : name |
| 1487 // -- rdx : receiver |
1496 // -- rsp[0] : return address | 1488 // -- rsp[0] : return address |
1497 // -- rsp[8] : receiver | |
1498 // ----------------------------------- | 1489 // ----------------------------------- |
1499 Label miss; | 1490 Label miss; |
1500 | 1491 |
1501 // Check that the map of the global has not changed. | 1492 // Check that the map of the global has not changed. |
1502 __ movq(rbx, Operand(rsp, kPointerSize)); | 1493 __ Cmp(FieldOperand(rdx, HeapObject::kMapOffset), |
1503 __ Cmp(FieldOperand(rbx, HeapObject::kMapOffset), | |
1504 Handle<Map>(object->map())); | 1494 Handle<Map>(object->map())); |
1505 __ j(not_equal, &miss); | 1495 __ j(not_equal, &miss); |
1506 | 1496 |
1507 // Store the value in the cell. | 1497 // Store the value in the cell. |
1508 __ Move(rcx, Handle<JSGlobalPropertyCell>(cell)); | 1498 __ Move(rcx, Handle<JSGlobalPropertyCell>(cell)); |
1509 __ movq(FieldOperand(rcx, JSGlobalPropertyCell::kValueOffset), rax); | 1499 __ movq(FieldOperand(rcx, JSGlobalPropertyCell::kValueOffset), rax); |
1510 | 1500 |
1511 // Return the value (register rax). | 1501 // Return the value (register rax). |
1512 __ IncrementCounter(&Counters::named_store_global_inline, 1); | 1502 __ IncrementCounter(&Counters::named_store_global_inline, 1); |
1513 __ ret(0); | 1503 __ ret(0); |
(...skipping 374 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1888 __ Jump(generic_construct_stub, RelocInfo::CODE_TARGET); | 1878 __ Jump(generic_construct_stub, RelocInfo::CODE_TARGET); |
1889 | 1879 |
1890 // Return the generated code. | 1880 // Return the generated code. |
1891 return GetCode(); | 1881 return GetCode(); |
1892 } | 1882 } |
1893 | 1883 |
1894 | 1884 |
1895 #undef __ | 1885 #undef __ |
1896 | 1886 |
1897 } } // namespace v8::internal | 1887 } } // namespace v8::internal |
OLD | NEW |