| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 |
| (...skipping 861 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 872 // Prepare arguments. | 872 // Prepare arguments. |
| 873 __ Addu(a2, sp, Operand(5 * kPointerSize)); | 873 __ Addu(a2, sp, Operand(5 * kPointerSize)); |
| 874 | 874 |
| 875 // Allocate the v8::Arguments structure in the arguments' space since | 875 // Allocate the v8::Arguments structure in the arguments' space since |
| 876 // it's not controlled by GC. | 876 // it's not controlled by GC. |
| 877 const int kApiStackSpace = 4; | 877 const int kApiStackSpace = 4; |
| 878 | 878 |
| 879 FrameScope frame_scope(masm, StackFrame::MANUAL); | 879 FrameScope frame_scope(masm, StackFrame::MANUAL); |
| 880 __ EnterExitFrame(false, kApiStackSpace); | 880 __ EnterExitFrame(false, kApiStackSpace); |
| 881 | 881 |
| 882 // NOTE: the O32 abi requires a0 to hold a special pointer when returning a | 882 // a0 = v8::Arguments& |
| 883 // struct from the function (which is currently the case). This means we pass | |
| 884 // the first argument in a1 instead of a0, if returns_handle is true. | |
| 885 // CallApiFunctionAndReturn will set up a0. | |
| 886 | |
| 887 Address function_address = v8::ToCData<Address>(api_call_info->callback()); | |
| 888 // TODO(dcarney): fix signatures using returns_handle | |
| 889 const bool returns_handle = false; | |
| 890 | |
| 891 Register first_arg = returns_handle ? a1 : a0; | |
| 892 Register second_arg = returns_handle ? a2 : a1; | |
| 893 | |
| 894 // first_arg = v8::Arguments& | |
| 895 // Arguments is built at sp + 1 (sp is a reserved spot for ra). | 883 // Arguments is built at sp + 1 (sp is a reserved spot for ra). |
| 896 __ Addu(first_arg, sp, kPointerSize); | 884 __ Addu(a0, sp, kPointerSize); |
| 897 | 885 |
| 898 // v8::Arguments::implicit_args_ | 886 // v8::Arguments::implicit_args_ |
| 899 __ sw(a2, MemOperand(first_arg, 0 * kPointerSize)); | 887 __ sw(a2, MemOperand(a0, 0 * kPointerSize)); |
| 900 // v8::Arguments::values_ | 888 // v8::Arguments::values_ |
| 901 __ Addu(t0, a2, Operand(argc * kPointerSize)); | 889 __ Addu(t0, a2, Operand(argc * kPointerSize)); |
| 902 __ sw(t0, MemOperand(first_arg, 1 * kPointerSize)); | 890 __ sw(t0, MemOperand(a0, 1 * kPointerSize)); |
| 903 // v8::Arguments::length_ = argc | 891 // v8::Arguments::length_ = argc |
| 904 __ li(t0, Operand(argc)); | 892 __ li(t0, Operand(argc)); |
| 905 __ sw(t0, MemOperand(first_arg, 2 * kPointerSize)); | 893 __ sw(t0, MemOperand(a0, 2 * kPointerSize)); |
| 906 // v8::Arguments::is_construct_call = 0 | 894 // v8::Arguments::is_construct_call = 0 |
| 907 __ sw(zero_reg, MemOperand(first_arg, 3 * kPointerSize)); | 895 __ sw(zero_reg, MemOperand(a0, 3 * kPointerSize)); |
| 908 | 896 |
| 909 const int kStackUnwindSpace = argc + kFastApiCallArguments + 1; | 897 const int kStackUnwindSpace = argc + kFastApiCallArguments + 1; |
| 898 Address function_address = v8::ToCData<Address>(api_call_info->callback()); |
| 910 ApiFunction fun(function_address); | 899 ApiFunction fun(function_address); |
| 911 ExternalReference::Type type = | 900 ExternalReference::Type type = ExternalReference::DIRECT_API_CALL; |
| 912 returns_handle ? | |
| 913 ExternalReference::DIRECT_API_CALL : | |
| 914 ExternalReference::DIRECT_API_CALL_NEW; | |
| 915 ExternalReference ref = | 901 ExternalReference ref = |
| 916 ExternalReference(&fun, | 902 ExternalReference(&fun, |
| 917 type, | 903 type, |
| 918 masm->isolate()); | 904 masm->isolate()); |
| 919 | |
| 920 Address thunk_address = FUNCTION_ADDR(&InvokeFunctionCallback); | 905 Address thunk_address = FUNCTION_ADDR(&InvokeFunctionCallback); |
| 921 ExternalReference::Type thunk_type = | 906 ExternalReference::Type thunk_type = ExternalReference::PROFILING_API_CALL; |
| 922 returns_handle ? | |
| 923 ExternalReference::PROFILING_API_CALL : | |
| 924 ExternalReference::PROFILING_API_CALL_NEW; | |
| 925 ApiFunction thunk_fun(thunk_address); | 907 ApiFunction thunk_fun(thunk_address); |
| 926 ExternalReference thunk_ref = ExternalReference(&thunk_fun, thunk_type, | 908 ExternalReference thunk_ref = ExternalReference(&thunk_fun, thunk_type, |
| 927 masm->isolate()); | 909 masm->isolate()); |
| 928 | 910 |
| 929 AllowExternalCallThatCantCauseGC scope(masm); | 911 AllowExternalCallThatCantCauseGC scope(masm); |
| 930 __ CallApiFunctionAndReturn(ref, | 912 __ CallApiFunctionAndReturn(ref, |
| 931 function_address, | 913 function_address, |
| 932 thunk_ref, | 914 thunk_ref, |
| 933 second_arg, | 915 a1, |
| 934 kStackUnwindSpace, | 916 kStackUnwindSpace, |
| 935 returns_handle, | |
| 936 kFastApiCallArguments + 1); | 917 kFastApiCallArguments + 1); |
| 937 } | 918 } |
| 938 | 919 |
| 939 class CallInterceptorCompiler BASE_EMBEDDED { | 920 class CallInterceptorCompiler BASE_EMBEDDED { |
| 940 public: | 921 public: |
| 941 CallInterceptorCompiler(StubCompiler* stub_compiler, | 922 CallInterceptorCompiler(StubCompiler* stub_compiler, |
| 942 const ParameterCount& arguments, | 923 const ParameterCount& arguments, |
| 943 Register name, | 924 Register name, |
| 944 Code::ExtraICState extra_ic_state) | 925 Code::ExtraICState extra_ic_state) |
| 945 : stub_compiler_(stub_compiler), | 926 : stub_compiler_(stub_compiler), |
| (...skipping 464 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1410 __ sw(reg, MemOperand(sp, 5 * kPointerSize)); | 1391 __ sw(reg, MemOperand(sp, 5 * kPointerSize)); |
| 1411 __ sw(scratch3(), MemOperand(sp, 4 * kPointerSize)); | 1392 __ sw(scratch3(), MemOperand(sp, 4 * kPointerSize)); |
| 1412 __ LoadRoot(scratch3(), Heap::kUndefinedValueRootIndex); | 1393 __ LoadRoot(scratch3(), Heap::kUndefinedValueRootIndex); |
| 1413 __ sw(scratch3(), MemOperand(sp, 3 * kPointerSize)); | 1394 __ sw(scratch3(), MemOperand(sp, 3 * kPointerSize)); |
| 1414 __ sw(scratch3(), MemOperand(sp, 2 * kPointerSize)); | 1395 __ sw(scratch3(), MemOperand(sp, 2 * kPointerSize)); |
| 1415 __ li(scratch4(), | 1396 __ li(scratch4(), |
| 1416 Operand(ExternalReference::isolate_address(isolate()))); | 1397 Operand(ExternalReference::isolate_address(isolate()))); |
| 1417 __ sw(scratch4(), MemOperand(sp, 1 * kPointerSize)); | 1398 __ sw(scratch4(), MemOperand(sp, 1 * kPointerSize)); |
| 1418 __ sw(name(), MemOperand(sp, 0 * kPointerSize)); | 1399 __ sw(name(), MemOperand(sp, 0 * kPointerSize)); |
| 1419 | 1400 |
| 1420 Address getter_address = v8::ToCData<Address>(callback->getter()); | |
| 1421 // TODO(dcarney): fix signatures using returns_handle | |
| 1422 const bool returns_handle = false; | |
| 1423 | |
| 1424 Register first_arg = returns_handle ? a1 : a0; | |
| 1425 Register second_arg = returns_handle ? a2 : a1; | |
| 1426 Register third_arg = returns_handle ? a3 : a2; | |
| 1427 | |
| 1428 __ mov(a2, scratch2()); // Saved in case scratch2 == a1. | 1401 __ mov(a2, scratch2()); // Saved in case scratch2 == a1. |
| 1429 __ mov(first_arg, sp); // (first argument - see note below) = Handle<Name> | 1402 __ mov(a0, sp); // (first argument - a0) = Handle<Name> |
| 1430 | |
| 1431 // NOTE: the O32 abi requires a0 to hold a special pointer when returning a | |
| 1432 // struct from the function (which is currently the case). This means we pass | |
| 1433 // the arguments in a1-a2 instead of a0-a1, if returns_handle is true. | |
| 1434 // CallApiFunctionAndReturn will set up a0. | |
| 1435 | 1403 |
| 1436 const int kApiStackSpace = 1; | 1404 const int kApiStackSpace = 1; |
| 1437 FrameScope frame_scope(masm(), StackFrame::MANUAL); | 1405 FrameScope frame_scope(masm(), StackFrame::MANUAL); |
| 1438 __ EnterExitFrame(false, kApiStackSpace); | 1406 __ EnterExitFrame(false, kApiStackSpace); |
| 1439 | 1407 |
| 1440 // Create AccessorInfo instance on the stack above the exit frame with | 1408 // Create AccessorInfo instance on the stack above the exit frame with |
| 1441 // scratch2 (internal::Object** args_) as the data. | 1409 // scratch2 (internal::Object** args_) as the data. |
| 1442 __ sw(a2, MemOperand(sp, kPointerSize)); | 1410 __ sw(a2, MemOperand(sp, kPointerSize)); |
| 1443 // (second argument - see note above) = AccessorInfo& | 1411 // (second argument - a1) = AccessorInfo& |
| 1444 __ Addu(second_arg, sp, kPointerSize); | 1412 __ Addu(a1, sp, kPointerSize); |
| 1445 | 1413 |
| 1446 const int kStackUnwindSpace = kFastApiCallArguments + 1; | 1414 const int kStackUnwindSpace = kFastApiCallArguments + 1; |
| 1447 | 1415 Address getter_address = v8::ToCData<Address>(callback->getter()); |
| 1448 ApiFunction fun(getter_address); | 1416 ApiFunction fun(getter_address); |
| 1449 ExternalReference::Type type = | 1417 ExternalReference::Type type = ExternalReference::DIRECT_GETTER_CALL; |
| 1450 returns_handle ? | |
| 1451 ExternalReference::DIRECT_GETTER_CALL : | |
| 1452 ExternalReference::DIRECT_GETTER_CALL_NEW; | |
| 1453 ExternalReference ref = ExternalReference(&fun, type, isolate()); | 1418 ExternalReference ref = ExternalReference(&fun, type, isolate()); |
| 1454 | 1419 |
| 1455 Address thunk_address = FUNCTION_ADDR(&InvokeAccessorGetterCallback); | 1420 Address thunk_address = FUNCTION_ADDR(&InvokeAccessorGetterCallback); |
| 1456 ExternalReference::Type thunk_type = | 1421 ExternalReference::Type thunk_type = |
| 1457 ExternalReference::PROFILING_GETTER_CALL_NEW; | 1422 ExternalReference::PROFILING_GETTER_CALL; |
| 1458 ApiFunction thunk_fun(thunk_address); | 1423 ApiFunction thunk_fun(thunk_address); |
| 1459 ExternalReference thunk_ref = ExternalReference(&thunk_fun, thunk_type, | 1424 ExternalReference thunk_ref = ExternalReference(&thunk_fun, thunk_type, |
| 1460 isolate()); | 1425 isolate()); |
| 1461 __ CallApiFunctionAndReturn(ref, | 1426 __ CallApiFunctionAndReturn(ref, |
| 1462 getter_address, | 1427 getter_address, |
| 1463 thunk_ref, | 1428 thunk_ref, |
| 1464 third_arg, | 1429 a2, |
| 1465 kStackUnwindSpace, | 1430 kStackUnwindSpace, |
| 1466 returns_handle, | |
| 1467 5); | 1431 5); |
| 1468 } | 1432 } |
| 1469 | 1433 |
| 1470 | 1434 |
| 1471 void BaseLoadStubCompiler::GenerateLoadInterceptor( | 1435 void BaseLoadStubCompiler::GenerateLoadInterceptor( |
| 1472 Register holder_reg, | 1436 Register holder_reg, |
| 1473 Handle<JSObject> object, | 1437 Handle<JSObject> object, |
| 1474 Handle<JSObject> interceptor_holder, | 1438 Handle<JSObject> interceptor_holder, |
| 1475 LookupResult* lookup, | 1439 LookupResult* lookup, |
| 1476 Handle<Name> name) { | 1440 Handle<Name> name) { |
| (...skipping 1728 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3205 // ----------------------------------- | 3169 // ----------------------------------- |
| 3206 TailCallBuiltin(masm, Builtins::kKeyedLoadIC_MissForceGeneric); | 3170 TailCallBuiltin(masm, Builtins::kKeyedLoadIC_MissForceGeneric); |
| 3207 } | 3171 } |
| 3208 | 3172 |
| 3209 | 3173 |
| 3210 #undef __ | 3174 #undef __ |
| 3211 | 3175 |
| 3212 } } // namespace v8::internal | 3176 } } // namespace v8::internal |
| 3213 | 3177 |
| 3214 #endif // V8_TARGET_ARCH_MIPS | 3178 #endif // V8_TARGET_ARCH_MIPS |
| OLD | NEW |