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

Side by Side Diff: src/mips/stub-cache-mips.cc

Issue 25549002: MIPS: Refactor PropertyCallbackInfo & FunctionCallbackInfo, part 3. (Closed) Base URL: https://github.com/v8/v8.git@gbl
Patch Set: Created 7 years, 2 months 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 | « no previous file | no next file » | 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 // 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 822 matching lines...) Expand 10 before | Expand all | Expand 10 after
833 bool restore_context) { 833 bool restore_context) {
834 // ----------- S t a t e ------------- 834 // ----------- S t a t e -------------
835 // -- sp[0] - sp[24] : FunctionCallbackInfo, incl. 835 // -- sp[0] - sp[24] : FunctionCallbackInfo, incl.
836 // : holder (set by CheckPrototypes) 836 // : holder (set by CheckPrototypes)
837 // -- sp[28] : last JS argument 837 // -- sp[28] : last JS argument
838 // -- ... 838 // -- ...
839 // -- sp[(argc + 6) * 4] : first JS argument 839 // -- sp[(argc + 6) * 4] : first JS argument
840 // -- sp[(argc + 7) * 4] : receiver 840 // -- sp[(argc + 7) * 4] : receiver
841 // ----------------------------------- 841 // -----------------------------------
842 typedef FunctionCallbackArguments FCA; 842 typedef FunctionCallbackArguments FCA;
843 const int kArgs = kFastApiCallArguments;
844 // Save calling context. 843 // Save calling context.
845 __ sw(cp, 844 __ sw(cp, MemOperand(sp, FCA::kContextSaveIndex * kPointerSize));
846 MemOperand(sp, (kArgs - 1 + FCA::kContextSaveIndex) * kPointerSize));
847 // Get the function and setup the context. 845 // Get the function and setup the context.
848 Handle<JSFunction> function = optimization.constant_function(); 846 Handle<JSFunction> function = optimization.constant_function();
849 __ LoadHeapObject(t1, function); 847 __ LoadHeapObject(t1, function);
850 __ lw(cp, FieldMemOperand(t1, JSFunction::kContextOffset)); 848 __ lw(cp, FieldMemOperand(t1, JSFunction::kContextOffset));
851 __ sw(t1, MemOperand(sp, (kArgs - 1 + FCA::kCalleeIndex) * kPointerSize)); 849 __ sw(t1, MemOperand(sp, FCA::kCalleeIndex * kPointerSize));
852 850
853 // Construct the FunctionCallbackInfo. 851 // Construct the FunctionCallbackInfo.
854 Handle<CallHandlerInfo> api_call_info = optimization.api_call_info(); 852 Handle<CallHandlerInfo> api_call_info = optimization.api_call_info();
855 Handle<Object> call_data(api_call_info->data(), masm->isolate()); 853 Handle<Object> call_data(api_call_info->data(), masm->isolate());
856 if (masm->isolate()->heap()->InNewSpace(*call_data)) { 854 if (masm->isolate()->heap()->InNewSpace(*call_data)) {
857 __ li(a0, api_call_info); 855 __ li(a0, api_call_info);
858 __ lw(t2, FieldMemOperand(a0, CallHandlerInfo::kDataOffset)); 856 __ lw(t2, FieldMemOperand(a0, CallHandlerInfo::kDataOffset));
859 } else { 857 } else {
860 __ li(t2, call_data); 858 __ li(t2, call_data);
861 } 859 }
862 // Store call data. 860 // Store call data.
863 __ sw(t2, MemOperand(sp, (kArgs - 1 + FCA::kDataIndex) * kPointerSize)); 861 __ sw(t2, MemOperand(sp, FCA::kDataIndex * kPointerSize));
864 // Store isolate. 862 // Store isolate.
865 __ li(t3, Operand(ExternalReference::isolate_address(masm->isolate()))); 863 __ li(t3, Operand(ExternalReference::isolate_address(masm->isolate())));
866 __ sw(t3, MemOperand(sp, (kArgs - 1 + FCA::kIsolateIndex) * kPointerSize)); 864 __ sw(t3, MemOperand(sp, FCA::kIsolateIndex * kPointerSize));
867 // Store ReturnValue default and ReturnValue. 865 // Store ReturnValue default and ReturnValue.
868 __ LoadRoot(t1, Heap::kUndefinedValueRootIndex); 866 __ LoadRoot(t1, Heap::kUndefinedValueRootIndex);
869 __ sw(t1, 867 __ sw(t1, MemOperand(sp, FCA::kReturnValueOffset * kPointerSize));
870 MemOperand(sp, (kArgs - 1 + FCA::kReturnValueOffset) * kPointerSize)); 868 __ sw(t1, MemOperand(sp, FCA::kReturnValueDefaultValueIndex * kPointerSize));
871 __ sw(t1,
872 MemOperand(sp,
873 (kArgs - 1 + FCA::kReturnValueDefaultValueIndex) * kPointerSize));
874 869
875 // Prepare arguments. 870 // Prepare arguments.
876 __ Addu(a2, sp, Operand((kArgs - 1) * kPointerSize)); 871 __ Move(a2, sp);
877 872
878 // Allocate the v8::Arguments structure in the arguments' space since 873 // Allocate the v8::Arguments structure in the arguments' space since
879 // it's not controlled by GC. 874 // it's not controlled by GC.
880 const int kApiStackSpace = 4; 875 const int kApiStackSpace = 4;
881 876
882 FrameScope frame_scope(masm, StackFrame::MANUAL); 877 FrameScope frame_scope(masm, StackFrame::MANUAL);
883 __ EnterExitFrame(false, kApiStackSpace); 878 __ EnterExitFrame(false, kApiStackSpace);
884 879
885 // a0 = v8::Arguments& 880 // a0 = FunctionCallbackInfo&
886 // Arguments is built at sp + 1 (sp is a reserved spot for ra). 881 // Arguments is built at sp + 1 (sp is a reserved spot for ra).
887 __ Addu(a0, sp, kPointerSize); 882 __ Addu(a0, sp, kPointerSize);
888 883 // FunctionCallbackInfo::implicit_args_
889 // v8::Arguments::implicit_args_
890 __ sw(a2, MemOperand(a0, 0 * kPointerSize)); 884 __ sw(a2, MemOperand(a0, 0 * kPointerSize));
891 // v8::Arguments::values_ 885 // FunctionCallbackInfo::values_
892 __ Addu(t0, a2, Operand(argc * kPointerSize)); 886 __ Addu(t0, a2, Operand((kFastApiCallArguments - 1 + argc) * kPointerSize));
893 __ sw(t0, MemOperand(a0, 1 * kPointerSize)); 887 __ sw(t0, MemOperand(a0, 1 * kPointerSize));
894 // v8::Arguments::length_ = argc 888 // FunctionCallbackInfo::length_ = argc
895 __ li(t0, Operand(argc)); 889 __ li(t0, Operand(argc));
896 __ sw(t0, MemOperand(a0, 2 * kPointerSize)); 890 __ sw(t0, MemOperand(a0, 2 * kPointerSize));
897 // v8::Arguments::is_construct_call = 0 891 // FunctionCallbackInfo::is_construct_call = 0
898 __ sw(zero_reg, MemOperand(a0, 3 * kPointerSize)); 892 __ sw(zero_reg, MemOperand(a0, 3 * kPointerSize));
899 893
900 const int kStackUnwindSpace = argc + kArgs + 1; 894 const int kStackUnwindSpace = argc + kFastApiCallArguments + 1;
901 Address function_address = v8::ToCData<Address>(api_call_info->callback()); 895 Address function_address = v8::ToCData<Address>(api_call_info->callback());
902 ApiFunction fun(function_address); 896 ApiFunction fun(function_address);
903 ExternalReference::Type type = ExternalReference::DIRECT_API_CALL; 897 ExternalReference::Type type = ExternalReference::DIRECT_API_CALL;
904 ExternalReference ref = 898 ExternalReference ref =
905 ExternalReference(&fun, 899 ExternalReference(&fun,
906 type, 900 type,
907 masm->isolate()); 901 masm->isolate());
908 Address thunk_address = FUNCTION_ADDR(&InvokeFunctionCallback); 902 Address thunk_address = FUNCTION_ADDR(&InvokeFunctionCallback);
909 ExternalReference::Type thunk_type = ExternalReference::PROFILING_API_CALL; 903 ExternalReference::Type thunk_type = ExternalReference::PROFILING_API_CALL;
910 ApiFunction thunk_fun(thunk_address); 904 ApiFunction thunk_fun(thunk_address);
911 ExternalReference thunk_ref = ExternalReference(&thunk_fun, thunk_type, 905 ExternalReference thunk_ref = ExternalReference(&thunk_fun, thunk_type,
912 masm->isolate()); 906 masm->isolate());
913 907
914 AllowExternalCallThatCantCauseGC scope(masm); 908 AllowExternalCallThatCantCauseGC scope(masm);
915 MemOperand context_restore_operand( 909 MemOperand context_restore_operand(
916 fp, (kArgs + 1 + FCA::kContextSaveIndex) * kPointerSize); 910 fp, (2 + FCA::kContextSaveIndex) * kPointerSize);
917 MemOperand return_value_operand( 911 MemOperand return_value_operand(
918 fp, (kArgs + 1 + FCA::kReturnValueOffset) * kPointerSize); 912 fp, (2 + FCA::kReturnValueOffset) * kPointerSize);
913
919 __ CallApiFunctionAndReturn(ref, 914 __ CallApiFunctionAndReturn(ref,
920 function_address, 915 function_address,
921 thunk_ref, 916 thunk_ref,
922 a1, 917 a1,
923 kStackUnwindSpace, 918 kStackUnwindSpace,
924 return_value_operand, 919 return_value_operand,
925 restore_context ? 920 restore_context ?
926 &context_restore_operand : NULL); 921 &context_restore_operand : NULL);
927 } 922 }
928 923
929 924
930 // Generate call to api function. 925 // Generate call to api function.
931 static void GenerateFastApiCall(MacroAssembler* masm, 926 static void GenerateFastApiCall(MacroAssembler* masm,
932 const CallOptimization& optimization, 927 const CallOptimization& optimization,
933 Register receiver, 928 Register receiver,
934 Register scratch, 929 Register scratch,
935 int argc, 930 int argc,
936 Register* values) { 931 Register* values) {
937 ASSERT(optimization.is_simple_api_call()); 932 ASSERT(optimization.is_simple_api_call());
938 ASSERT(!receiver.is(scratch)); 933 ASSERT(!receiver.is(scratch));
939 934
935 typedef FunctionCallbackArguments FCA;
940 const int stack_space = kFastApiCallArguments + argc + 1; 936 const int stack_space = kFastApiCallArguments + argc + 1;
941 const int kHolderIndex = kFastApiCallArguments +
942 FunctionCallbackArguments::kHolderIndex - 1;
943 // Assign stack space for the call arguments. 937 // Assign stack space for the call arguments.
944 __ Subu(sp, sp, Operand(stack_space * kPointerSize)); 938 __ Subu(sp, sp, Operand(stack_space * kPointerSize));
945 // Write holder to stack frame. 939 // Write holder to stack frame.
946 __ sw(receiver, MemOperand(sp, kHolderIndex * kPointerSize)); 940 __ sw(receiver, MemOperand(sp, FCA::kHolderIndex * kPointerSize));
947 // Write receiver to stack frame. 941 // Write receiver to stack frame.
948 int index = stack_space - 1; 942 int index = stack_space - 1;
949 __ sw(receiver, MemOperand(sp, index * kPointerSize)); 943 __ sw(receiver, MemOperand(sp, index * kPointerSize));
950 // Write the arguments to stack frame. 944 // Write the arguments to stack frame.
951 for (int i = 0; i < argc; i++) { 945 for (int i = 0; i < argc; i++) {
952 ASSERT(!receiver.is(values[i])); 946 ASSERT(!receiver.is(values[i]));
953 ASSERT(!scratch.is(values[i])); 947 ASSERT(!scratch.is(values[i]));
954 __ sw(receiver, MemOperand(sp, index-- * kPointerSize)); 948 __ sw(receiver, MemOperand(sp, index-- * kPointerSize));
955 } 949 }
956 950
(...skipping 232 matching lines...) Expand 10 before | Expand all | Expand 10 after
1189 Register StubCompiler::CheckPrototypes(Handle<JSObject> object, 1183 Register StubCompiler::CheckPrototypes(Handle<JSObject> object,
1190 Register object_reg, 1184 Register object_reg,
1191 Handle<JSObject> holder, 1185 Handle<JSObject> holder,
1192 Register holder_reg, 1186 Register holder_reg,
1193 Register scratch1, 1187 Register scratch1,
1194 Register scratch2, 1188 Register scratch2,
1195 Handle<Name> name, 1189 Handle<Name> name,
1196 int save_at_depth, 1190 int save_at_depth,
1197 Label* miss, 1191 Label* miss,
1198 PrototypeCheckType check) { 1192 PrototypeCheckType check) {
1199 const int kHolderIndex = kFastApiCallArguments +
1200 FunctionCallbackArguments::kHolderIndex - 1;
1201 // Make sure that the type feedback oracle harvests the receiver map. 1193 // Make sure that the type feedback oracle harvests the receiver map.
1202 // TODO(svenpanne) Remove this hack when all ICs are reworked. 1194 // TODO(svenpanne) Remove this hack when all ICs are reworked.
1203 __ li(scratch1, Operand(Handle<Map>(object->map()))); 1195 __ li(scratch1, Operand(Handle<Map>(object->map())));
1204 1196
1205 Handle<JSObject> first = object; 1197 Handle<JSObject> first = object;
1206 // Make sure there's no overlap between holder and object registers. 1198 // Make sure there's no overlap between holder and object registers.
1207 ASSERT(!scratch1.is(object_reg) && !scratch1.is(holder_reg)); 1199 ASSERT(!scratch1.is(object_reg) && !scratch1.is(holder_reg));
1208 ASSERT(!scratch2.is(object_reg) && !scratch2.is(holder_reg) 1200 ASSERT(!scratch2.is(object_reg) && !scratch2.is(holder_reg)
1209 && !scratch2.is(scratch1)); 1201 && !scratch2.is(scratch1));
1210 1202
1211 // Keep track of the current object in register reg. 1203 // Keep track of the current object in register reg.
1212 Register reg = object_reg; 1204 Register reg = object_reg;
1213 int depth = 0; 1205 int depth = 0;
1214 1206
1207 typedef FunctionCallbackArguments FCA;
1215 if (save_at_depth == depth) { 1208 if (save_at_depth == depth) {
1216 __ sw(reg, MemOperand(sp, kHolderIndex * kPointerSize)); 1209 __ sw(reg, MemOperand(sp, FCA::kHolderIndex * kPointerSize));
1217 } 1210 }
1218 1211
1219 // Check the maps in the prototype chain. 1212 // Check the maps in the prototype chain.
1220 // Traverse the prototype chain from the object and do map checks. 1213 // Traverse the prototype chain from the object and do map checks.
1221 Handle<JSObject> current = object; 1214 Handle<JSObject> current = object;
1222 while (!current.is_identical_to(holder)) { 1215 while (!current.is_identical_to(holder)) {
1223 ++depth; 1216 ++depth;
1224 1217
1225 // Only global objects and objects that do not require access 1218 // Only global objects and objects that do not require access
1226 // checks are allowed in stubs. 1219 // checks are allowed in stubs.
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
1264 // The prototype is in new space; we cannot store a reference to it 1257 // The prototype is in new space; we cannot store a reference to it
1265 // in the code. Load it from the map. 1258 // in the code. Load it from the map.
1266 __ lw(reg, FieldMemOperand(map_reg, Map::kPrototypeOffset)); 1259 __ lw(reg, FieldMemOperand(map_reg, Map::kPrototypeOffset));
1267 } else { 1260 } else {
1268 // The prototype is in old space; load it directly. 1261 // The prototype is in old space; load it directly.
1269 __ li(reg, Operand(prototype)); 1262 __ li(reg, Operand(prototype));
1270 } 1263 }
1271 } 1264 }
1272 1265
1273 if (save_at_depth == depth) { 1266 if (save_at_depth == depth) {
1274 __ sw(reg, MemOperand(sp, kHolderIndex * kPointerSize)); 1267 __ sw(reg, MemOperand(sp, FCA::kHolderIndex * kPointerSize));
1275 } 1268 }
1276 1269
1277 // Go to the next object in the prototype chain. 1270 // Go to the next object in the prototype chain.
1278 current = prototype; 1271 current = prototype;
1279 } 1272 }
1280 1273
1281 // Log the check depth. 1274 // Log the check depth.
1282 LOG(isolate(), IntEvent("check-maps-depth", depth + 1)); 1275 LOG(isolate(), IntEvent("check-maps-depth", depth + 1));
1283 1276
1284 if (!holder.is_identical_to(first) || check == CHECK_ALL_MAPS) { 1277 if (!holder.is_identical_to(first) || check == CHECK_ALL_MAPS) {
(...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after
1422 GenerateFastApiCall( 1415 GenerateFastApiCall(
1423 masm(), call_optimization, receiver(), scratch3(), 0, NULL); 1416 masm(), call_optimization, receiver(), scratch3(), 0, NULL);
1424 } 1417 }
1425 1418
1426 1419
1427 void BaseLoadStubCompiler::GenerateLoadCallback( 1420 void BaseLoadStubCompiler::GenerateLoadCallback(
1428 Register reg, 1421 Register reg,
1429 Handle<ExecutableAccessorInfo> callback) { 1422 Handle<ExecutableAccessorInfo> callback) {
1430 // Build AccessorInfo::args_ list on the stack and push property name below 1423 // Build AccessorInfo::args_ list on the stack and push property name below
1431 // the exit frame to make GC aware of them and store pointers to them. 1424 // the exit frame to make GC aware of them and store pointers to them.
1432 STATIC_ASSERT(PropertyCallbackArguments::kThisIndex == 0); 1425 STATIC_ASSERT(PropertyCallbackArguments::kHolderIndex == 0);
1433 STATIC_ASSERT(PropertyCallbackArguments::kDataIndex == -1); 1426 STATIC_ASSERT(PropertyCallbackArguments::kIsolateIndex == 1);
1434 STATIC_ASSERT(PropertyCallbackArguments::kReturnValueOffset == -2); 1427 STATIC_ASSERT(PropertyCallbackArguments::kReturnValueDefaultValueIndex == 2);
1435 STATIC_ASSERT(PropertyCallbackArguments::kReturnValueDefaultValueIndex == -3); 1428 STATIC_ASSERT(PropertyCallbackArguments::kReturnValueOffset == 3);
1436 STATIC_ASSERT(PropertyCallbackArguments::kIsolateIndex == -4); 1429 STATIC_ASSERT(PropertyCallbackArguments::kDataIndex == 4);
1437 STATIC_ASSERT(PropertyCallbackArguments::kHolderIndex == -5); 1430 STATIC_ASSERT(PropertyCallbackArguments::kThisIndex == 5);
1431 STATIC_ASSERT(PropertyCallbackArguments::kArgsLength == 6);
1438 ASSERT(!scratch2().is(reg)); 1432 ASSERT(!scratch2().is(reg));
1439 ASSERT(!scratch3().is(reg)); 1433 ASSERT(!scratch3().is(reg));
1440 ASSERT(!scratch4().is(reg)); 1434 ASSERT(!scratch4().is(reg));
1441 __ push(receiver()); 1435 __ push(receiver());
1442 __ mov(scratch2(), sp); // scratch2 = AccessorInfo::args_
1443 if (heap()->InNewSpace(callback->data())) { 1436 if (heap()->InNewSpace(callback->data())) {
1444 __ li(scratch3(), callback); 1437 __ li(scratch3(), callback);
1445 __ lw(scratch3(), FieldMemOperand(scratch3(), 1438 __ lw(scratch3(), FieldMemOperand(scratch3(),
1446 ExecutableAccessorInfo::kDataOffset)); 1439 ExecutableAccessorInfo::kDataOffset));
1447 } else { 1440 } else {
1448 __ li(scratch3(), Handle<Object>(callback->data(), isolate())); 1441 __ li(scratch3(), Handle<Object>(callback->data(), isolate()));
1449 } 1442 }
1450 __ Subu(sp, sp, 6 * kPointerSize); 1443 __ Subu(sp, sp, 6 * kPointerSize);
1451 __ sw(scratch3(), MemOperand(sp, 5 * kPointerSize)); 1444 __ sw(scratch3(), MemOperand(sp, 5 * kPointerSize));
1452 __ LoadRoot(scratch3(), Heap::kUndefinedValueRootIndex); 1445 __ LoadRoot(scratch3(), Heap::kUndefinedValueRootIndex);
1453 __ sw(scratch3(), MemOperand(sp, 4 * kPointerSize)); 1446 __ sw(scratch3(), MemOperand(sp, 4 * kPointerSize));
1454 __ sw(scratch3(), MemOperand(sp, 3 * kPointerSize)); 1447 __ sw(scratch3(), MemOperand(sp, 3 * kPointerSize));
1455 __ li(scratch4(), 1448 __ li(scratch4(),
1456 Operand(ExternalReference::isolate_address(isolate()))); 1449 Operand(ExternalReference::isolate_address(isolate())));
1457 __ sw(scratch4(), MemOperand(sp, 2 * kPointerSize)); 1450 __ sw(scratch4(), MemOperand(sp, 2 * kPointerSize));
1458 __ sw(reg, MemOperand(sp, 1 * kPointerSize)); 1451 __ sw(reg, MemOperand(sp, 1 * kPointerSize));
1459 __ sw(name(), MemOperand(sp, 0 * kPointerSize)); 1452 __ sw(name(), MemOperand(sp, 0 * kPointerSize));
1453 __ Addu(scratch2(), sp, 1 * kPointerSize);
1460 1454
1461 __ mov(a2, scratch2()); // Saved in case scratch2 == a1. 1455 __ mov(a2, scratch2()); // Saved in case scratch2 == a1.
1462 __ mov(a0, sp); // (first argument - a0) = Handle<Name> 1456 __ mov(a0, sp); // (first argument - a0) = Handle<Name>
1463 1457
1464 const int kApiStackSpace = 1; 1458 const int kApiStackSpace = 1;
1465 FrameScope frame_scope(masm(), StackFrame::MANUAL); 1459 FrameScope frame_scope(masm(), StackFrame::MANUAL);
1466 __ EnterExitFrame(false, kApiStackSpace); 1460 __ EnterExitFrame(false, kApiStackSpace);
1467 1461
1468 // Create AccessorInfo instance on the stack above the exit frame with 1462 // Create PropertyAccessorInfo instance on the stack above the exit frame with
1469 // scratch2 (internal::Object** args_) as the data. 1463 // scratch2 (internal::Object** args_) as the data.
1470 __ sw(a2, MemOperand(sp, kPointerSize)); 1464 __ sw(a2, MemOperand(sp, kPointerSize));
1471 // (second argument - a1) = AccessorInfo& 1465 // (second argument - a1) = AccessorInfo&
1472 __ Addu(a1, sp, kPointerSize); 1466 __ Addu(a1, sp, kPointerSize);
1473 1467
1474 const int kStackUnwindSpace = PropertyCallbackArguments::kArgsLength + 1; 1468 const int kStackUnwindSpace = PropertyCallbackArguments::kArgsLength + 1;
1475 Address getter_address = v8::ToCData<Address>(callback->getter()); 1469 Address getter_address = v8::ToCData<Address>(callback->getter());
1476 ApiFunction fun(getter_address); 1470 ApiFunction fun(getter_address);
1477 ExternalReference::Type type = ExternalReference::DIRECT_GETTER_CALL; 1471 ExternalReference::Type type = ExternalReference::DIRECT_GETTER_CALL;
1478 ExternalReference ref = ExternalReference(&fun, type, isolate()); 1472 ExternalReference ref = ExternalReference(&fun, type, isolate());
(...skipping 1729 matching lines...) Expand 10 before | Expand all | Expand 10 after
3208 // ----------------------------------- 3202 // -----------------------------------
3209 TailCallBuiltin(masm, Builtins::kKeyedLoadIC_MissForceGeneric); 3203 TailCallBuiltin(masm, Builtins::kKeyedLoadIC_MissForceGeneric);
3210 } 3204 }
3211 3205
3212 3206
3213 #undef __ 3207 #undef __
3214 3208
3215 } } // namespace v8::internal 3209 } } // namespace v8::internal
3216 3210
3217 #endif // V8_TARGET_ARCH_MIPS 3211 #endif // V8_TARGET_ARCH_MIPS
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698