| 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 | 
|---|