| 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 911 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 922 // Otherwise the elements backing store is set to the empty FixedArray. | 922 // Otherwise the elements backing store is set to the empty FixedArray. |
| 923 static void AllocateEmptyJSArray(MacroAssembler* masm, | 923 static void AllocateEmptyJSArray(MacroAssembler* masm, |
| 924 Register array_function, | 924 Register array_function, |
| 925 Register result, | 925 Register result, |
| 926 Register scratch1, | 926 Register scratch1, |
| 927 Register scratch2, | 927 Register scratch2, |
| 928 Register scratch3, | 928 Register scratch3, |
| 929 Label* gc_required) { | 929 Label* gc_required) { |
| 930 const int initial_capacity = JSArray::kPreallocatedArrayElements; | 930 const int initial_capacity = JSArray::kPreallocatedArrayElements; |
| 931 STATIC_ASSERT(initial_capacity >= 0); | 931 STATIC_ASSERT(initial_capacity >= 0); |
| 932 // Load the initial map from the array function. | 932 |
| 933 __ mov(scratch1, FieldOperand(array_function, | 933 __ LoadGlobalInitialConstructedArrayMap(array_function, scratch2, scratch1); |
| 934 JSFunction::kPrototypeOrInitialMapOffset)); | |
| 935 | 934 |
| 936 // Allocate the JSArray object together with space for a fixed array with the | 935 // Allocate the JSArray object together with space for a fixed array with the |
| 937 // requested elements. | 936 // requested elements. |
| 938 int size = JSArray::kSize; | 937 int size = JSArray::kSize; |
| 939 if (initial_capacity > 0) { | 938 if (initial_capacity > 0) { |
| 940 size += FixedArray::SizeFor(initial_capacity); | 939 size += FixedArray::SizeFor(initial_capacity); |
| 941 } | 940 } |
| 942 __ AllocateInNewSpace(size, | 941 __ AllocateInNewSpace(size, |
| 943 result, | 942 result, |
| 944 scratch2, | 943 scratch2, |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1027 Register result, | 1026 Register result, |
| 1028 Register elements_array, | 1027 Register elements_array, |
| 1029 Register elements_array_end, | 1028 Register elements_array_end, |
| 1030 Register scratch, | 1029 Register scratch, |
| 1031 bool fill_with_hole, | 1030 bool fill_with_hole, |
| 1032 Label* gc_required) { | 1031 Label* gc_required) { |
| 1033 ASSERT(scratch.is(edi)); // rep stos destination | 1032 ASSERT(scratch.is(edi)); // rep stos destination |
| 1034 ASSERT(!fill_with_hole || array_size.is(ecx)); // rep stos count | 1033 ASSERT(!fill_with_hole || array_size.is(ecx)); // rep stos count |
| 1035 ASSERT(!fill_with_hole || !result.is(eax)); // result is never eax | 1034 ASSERT(!fill_with_hole || !result.is(eax)); // result is never eax |
| 1036 | 1035 |
| 1037 // Load the initial map from the array function. | 1036 __ LoadGlobalInitialConstructedArrayMap(array_function, |
| 1038 __ mov(elements_array, | 1037 scratch, |
| 1039 FieldOperand(array_function, | 1038 elements_array); |
| 1040 JSFunction::kPrototypeOrInitialMapOffset)); | |
| 1041 | 1039 |
| 1042 // Allocate the JSArray object together with space for a FixedArray with the | 1040 // Allocate the JSArray object together with space for a FixedArray with the |
| 1043 // requested elements. | 1041 // requested elements. |
| 1044 STATIC_ASSERT(kSmiTagSize == 1 && kSmiTag == 0); | 1042 STATIC_ASSERT(kSmiTagSize == 1 && kSmiTag == 0); |
| 1045 __ AllocateInNewSpace(JSArray::kSize + FixedArray::kHeaderSize, | 1043 __ AllocateInNewSpace(JSArray::kSize + FixedArray::kHeaderSize, |
| 1046 times_half_pointer_size, // array_size is a smi. | 1044 times_half_pointer_size, // array_size is a smi. |
| 1047 array_size, | 1045 array_size, |
| 1048 result, | 1046 result, |
| 1049 elements_array_end, | 1047 elements_array_end, |
| 1050 scratch, | 1048 scratch, |
| (...skipping 263 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1314 // -- eax : argc | 1312 // -- eax : argc |
| 1315 // -- esp[0] : return address | 1313 // -- esp[0] : return address |
| 1316 // -- esp[4] : last argument | 1314 // -- esp[4] : last argument |
| 1317 // ----------------------------------- | 1315 // ----------------------------------- |
| 1318 Label generic_array_code; | 1316 Label generic_array_code; |
| 1319 | 1317 |
| 1320 // Get the InternalArray function. | 1318 // Get the InternalArray function. |
| 1321 __ LoadGlobalFunction(Context::INTERNAL_ARRAY_FUNCTION_INDEX, edi); | 1319 __ LoadGlobalFunction(Context::INTERNAL_ARRAY_FUNCTION_INDEX, edi); |
| 1322 | 1320 |
| 1323 if (FLAG_debug_code) { | 1321 if (FLAG_debug_code) { |
| 1324 // Initial map for the builtin InternalArray function shoud be a map. | 1322 // Initial map for the builtin InternalArray function should be a map. |
| 1325 __ mov(ebx, FieldOperand(edi, JSFunction::kPrototypeOrInitialMapOffset)); | 1323 __ mov(ebx, FieldOperand(edi, JSFunction::kPrototypeOrInitialMapOffset)); |
| 1326 // Will both indicate a NULL and a Smi. | 1324 // Will both indicate a NULL and a Smi. |
| 1327 __ test(ebx, Immediate(kSmiTagMask)); | 1325 __ test(ebx, Immediate(kSmiTagMask)); |
| 1328 __ Assert(not_zero, "Unexpected initial map for InternalArray function"); | 1326 __ Assert(not_zero, "Unexpected initial map for InternalArray function"); |
| 1329 __ CmpObjectType(ebx, MAP_TYPE, ecx); | 1327 __ CmpObjectType(ebx, MAP_TYPE, ecx); |
| 1330 __ Assert(equal, "Unexpected initial map for InternalArray function"); | 1328 __ Assert(equal, "Unexpected initial map for InternalArray function"); |
| 1331 } | 1329 } |
| 1332 | 1330 |
| 1333 // Run the native code for the InternalArray function called as a normal | 1331 // Run the native code for the InternalArray function called as a normal |
| 1334 // function. | 1332 // function. |
| 1335 ArrayNativeCode(masm, false, &generic_array_code); | 1333 ArrayNativeCode(masm, false, &generic_array_code); |
| 1336 | 1334 |
| 1337 // Jump to the generic array code in case the specialized code cannot handle | 1335 // Jump to the generic internal array code in case the specialized code cannot |
| 1338 // the construction. | 1336 // handle the construction. |
| 1339 __ bind(&generic_array_code); | 1337 __ bind(&generic_array_code); |
| 1340 Handle<Code> array_code = | 1338 Handle<Code> array_code = |
| 1341 masm->isolate()->builtins()->InternalArrayCodeGeneric(); | 1339 masm->isolate()->builtins()->InternalArrayCodeGeneric(); |
| 1342 __ jmp(array_code, RelocInfo::CODE_TARGET); | 1340 __ jmp(array_code, RelocInfo::CODE_TARGET); |
| 1343 } | 1341 } |
| 1344 | 1342 |
| 1345 | 1343 |
| 1346 void Builtins::Generate_ArrayCode(MacroAssembler* masm) { | 1344 void Builtins::Generate_ArrayCode(MacroAssembler* masm) { |
| 1347 // ----------- S t a t e ------------- | 1345 // ----------- S t a t e ------------- |
| 1348 // -- eax : argc | 1346 // -- eax : argc |
| 1349 // -- esp[0] : return address | 1347 // -- esp[0] : return address |
| 1350 // -- esp[4] : last argument | 1348 // -- esp[4] : last argument |
| 1351 // ----------------------------------- | 1349 // ----------------------------------- |
| 1352 Label generic_array_code; | 1350 Label generic_array_code; |
| 1353 | 1351 |
| 1354 // Get the Array function. | 1352 // Get the Array function. |
| 1355 __ LoadGlobalFunction(Context::ARRAY_FUNCTION_INDEX, edi); | 1353 __ LoadGlobalFunction(Context::ARRAY_FUNCTION_INDEX, edi); |
| 1356 | 1354 |
| 1357 if (FLAG_debug_code) { | 1355 if (FLAG_debug_code) { |
| 1358 // Initial map for the builtin Array function shoud be a map. | 1356 // Initial map for the builtin Array function should be a map. |
| 1359 __ mov(ebx, FieldOperand(edi, JSFunction::kPrototypeOrInitialMapOffset)); | 1357 __ mov(ebx, FieldOperand(edi, JSFunction::kPrototypeOrInitialMapOffset)); |
| 1360 // Will both indicate a NULL and a Smi. | 1358 // Will both indicate a NULL and a Smi. |
| 1361 __ test(ebx, Immediate(kSmiTagMask)); | 1359 __ test(ebx, Immediate(kSmiTagMask)); |
| 1362 __ Assert(not_zero, "Unexpected initial map for Array function"); | 1360 __ Assert(not_zero, "Unexpected initial map for Array function"); |
| 1363 __ CmpObjectType(ebx, MAP_TYPE, ecx); | 1361 __ CmpObjectType(ebx, MAP_TYPE, ecx); |
| 1364 __ Assert(equal, "Unexpected initial map for Array function"); | 1362 __ Assert(equal, "Unexpected initial map for Array function"); |
| 1365 } | 1363 } |
| 1366 | 1364 |
| 1367 // Run the native code for the Array function called as a normal function. | 1365 // Run the native code for the Array function called as a normal function. |
| 1368 ArrayNativeCode(masm, false, &generic_array_code); | 1366 ArrayNativeCode(masm, false, &generic_array_code); |
| (...skipping 355 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1724 Deoptimizer::EntryGenerator generator(masm, Deoptimizer::OSR); | 1722 Deoptimizer::EntryGenerator generator(masm, Deoptimizer::OSR); |
| 1725 generator.Generate(); | 1723 generator.Generate(); |
| 1726 } | 1724 } |
| 1727 | 1725 |
| 1728 | 1726 |
| 1729 #undef __ | 1727 #undef __ |
| 1730 } | 1728 } |
| 1731 } // namespace v8::internal | 1729 } // namespace v8::internal |
| 1732 | 1730 |
| 1733 #endif // V8_TARGET_ARCH_IA32 | 1731 #endif // V8_TARGET_ARCH_IA32 |
| OLD | NEW |