OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/v8.h" | 5 #include "src/v8.h" |
6 | 6 |
7 #if V8_TARGET_ARCH_ARM64 | 7 #if V8_TARGET_ARCH_ARM64 |
8 | 8 |
9 #include "src/codegen.h" | 9 #include "src/codegen.h" |
10 #include "src/ic/ic.h" | 10 #include "src/ic/ic.h" |
(...skipping 336 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
347 __ Bind(&slow); | 347 __ Bind(&slow); |
348 GenerateRuntimeGetProperty(masm); | 348 GenerateRuntimeGetProperty(masm); |
349 } | 349 } |
350 | 350 |
351 | 351 |
352 void LoadIC::GenerateMiss(MacroAssembler* masm) { | 352 void LoadIC::GenerateMiss(MacroAssembler* masm) { |
353 // The return address is in lr. | 353 // The return address is in lr. |
354 Isolate* isolate = masm->isolate(); | 354 Isolate* isolate = masm->isolate(); |
355 ASM_LOCATION("LoadIC::GenerateMiss"); | 355 ASM_LOCATION("LoadIC::GenerateMiss"); |
356 | 356 |
357 __ IncrementCounter(isolate->counters()->load_miss(), 1, x3, x4); | 357 DCHECK(!FLAG_vector_ics || |
| 358 !AreAliased(x4, x5, VectorLoadICDescriptor::SlotRegister(), |
| 359 VectorLoadICDescriptor::VectorRegister())); |
| 360 __ IncrementCounter(isolate->counters()->load_miss(), 1, x4, x5); |
358 | 361 |
359 // Perform tail call to the entry. | 362 // Perform tail call to the entry. |
360 if (FLAG_vector_ics) { | 363 if (FLAG_vector_ics) { |
361 __ Push(VectorLoadICDescriptor::ReceiverRegister(), | 364 __ Push(VectorLoadICDescriptor::ReceiverRegister(), |
362 VectorLoadICDescriptor::NameRegister(), | 365 VectorLoadICDescriptor::NameRegister(), |
363 VectorLoadICDescriptor::SlotRegister(), | 366 VectorLoadICDescriptor::SlotRegister(), |
364 VectorLoadICDescriptor::VectorRegister()); | 367 VectorLoadICDescriptor::VectorRegister()); |
365 } else { | 368 } else { |
366 __ Push(LoadDescriptor::ReceiverRegister(), LoadDescriptor::NameRegister()); | 369 __ Push(LoadDescriptor::ReceiverRegister(), LoadDescriptor::NameRegister()); |
367 } | 370 } |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
421 __ Ret(); | 424 __ Ret(); |
422 __ Bind(&slow); | 425 __ Bind(&slow); |
423 GenerateMiss(masm); | 426 GenerateMiss(masm); |
424 } | 427 } |
425 | 428 |
426 | 429 |
427 void KeyedLoadIC::GenerateMiss(MacroAssembler* masm) { | 430 void KeyedLoadIC::GenerateMiss(MacroAssembler* masm) { |
428 // The return address is in lr. | 431 // The return address is in lr. |
429 Isolate* isolate = masm->isolate(); | 432 Isolate* isolate = masm->isolate(); |
430 | 433 |
| 434 DCHECK(!FLAG_vector_ics || |
| 435 !AreAliased(x10, x11, VectorLoadICDescriptor::SlotRegister(), |
| 436 VectorLoadICDescriptor::VectorRegister())); |
431 __ IncrementCounter(isolate->counters()->keyed_load_miss(), 1, x10, x11); | 437 __ IncrementCounter(isolate->counters()->keyed_load_miss(), 1, x10, x11); |
432 | 438 |
433 if (FLAG_vector_ics) { | 439 if (FLAG_vector_ics) { |
434 __ Push(VectorLoadICDescriptor::ReceiverRegister(), | 440 __ Push(VectorLoadICDescriptor::ReceiverRegister(), |
435 VectorLoadICDescriptor::NameRegister(), | 441 VectorLoadICDescriptor::NameRegister(), |
436 VectorLoadICDescriptor::SlotRegister(), | 442 VectorLoadICDescriptor::SlotRegister(), |
437 VectorLoadICDescriptor::VectorRegister()); | 443 VectorLoadICDescriptor::VectorRegister()); |
438 } else { | 444 } else { |
439 __ Push(LoadDescriptor::ReceiverRegister(), LoadDescriptor::NameRegister()); | 445 __ Push(LoadDescriptor::ReceiverRegister(), LoadDescriptor::NameRegister()); |
440 } | 446 } |
(...skipping 404 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
845 // x2: receiver | 851 // x2: receiver |
846 PropertyICCompiler::GenerateRuntimeSetProperty(masm, strict_mode); | 852 PropertyICCompiler::GenerateRuntimeSetProperty(masm, strict_mode); |
847 // Never returns to here. | 853 // Never returns to here. |
848 | 854 |
849 __ bind(&maybe_name_key); | 855 __ bind(&maybe_name_key); |
850 __ Ldr(x10, FieldMemOperand(key, HeapObject::kMapOffset)); | 856 __ Ldr(x10, FieldMemOperand(key, HeapObject::kMapOffset)); |
851 __ Ldrb(x10, FieldMemOperand(x10, Map::kInstanceTypeOffset)); | 857 __ Ldrb(x10, FieldMemOperand(x10, Map::kInstanceTypeOffset)); |
852 __ JumpIfNotUniqueNameInstanceType(x10, &slow); | 858 __ JumpIfNotUniqueNameInstanceType(x10, &slow); |
853 Code::Flags flags = Code::RemoveTypeAndHolderFromFlags( | 859 Code::Flags flags = Code::RemoveTypeAndHolderFromFlags( |
854 Code::ComputeHandlerFlags(Code::STORE_IC)); | 860 Code::ComputeHandlerFlags(Code::STORE_IC)); |
855 masm->isolate()->stub_cache()->GenerateProbe(masm, flags, false, receiver, | 861 masm->isolate()->stub_cache()->GenerateProbe( |
856 key, x3, x4, x5, x6); | 862 masm, Code::STORE_IC, flags, false, receiver, key, x3, x4, x5, x6); |
857 // Cache miss. | 863 // Cache miss. |
858 __ B(&miss); | 864 __ B(&miss); |
859 | 865 |
860 __ Bind(&extra); | 866 __ Bind(&extra); |
861 // Extra capacity case: Check if there is extra capacity to | 867 // Extra capacity case: Check if there is extra capacity to |
862 // perform the store and update the length. Used for adding one | 868 // perform the store and update the length. Used for adding one |
863 // element to the array by writing to array[array.length]. | 869 // element to the array by writing to array[array.length]. |
864 | 870 |
865 // Check for room in the elements backing store. | 871 // Check for room in the elements backing store. |
866 // Both the key and the length of FixedArray are smis. | 872 // Both the key and the length of FixedArray are smis. |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
905 | 911 |
906 void StoreIC::GenerateMegamorphic(MacroAssembler* masm) { | 912 void StoreIC::GenerateMegamorphic(MacroAssembler* masm) { |
907 Register receiver = StoreDescriptor::ReceiverRegister(); | 913 Register receiver = StoreDescriptor::ReceiverRegister(); |
908 Register name = StoreDescriptor::NameRegister(); | 914 Register name = StoreDescriptor::NameRegister(); |
909 DCHECK(!AreAliased(receiver, name, StoreDescriptor::ValueRegister(), x3, x4, | 915 DCHECK(!AreAliased(receiver, name, StoreDescriptor::ValueRegister(), x3, x4, |
910 x5, x6)); | 916 x5, x6)); |
911 | 917 |
912 // Probe the stub cache. | 918 // Probe the stub cache. |
913 Code::Flags flags = Code::RemoveTypeAndHolderFromFlags( | 919 Code::Flags flags = Code::RemoveTypeAndHolderFromFlags( |
914 Code::ComputeHandlerFlags(Code::STORE_IC)); | 920 Code::ComputeHandlerFlags(Code::STORE_IC)); |
915 masm->isolate()->stub_cache()->GenerateProbe(masm, flags, false, receiver, | 921 masm->isolate()->stub_cache()->GenerateProbe( |
916 name, x3, x4, x5, x6); | 922 masm, Code::STORE_IC, flags, false, receiver, name, x3, x4, x5, x6); |
917 | 923 |
918 // Cache miss: Jump to runtime. | 924 // Cache miss: Jump to runtime. |
919 GenerateMiss(masm); | 925 GenerateMiss(masm); |
920 } | 926 } |
921 | 927 |
922 | 928 |
923 void StoreIC::GenerateMiss(MacroAssembler* masm) { | 929 void StoreIC::GenerateMiss(MacroAssembler* masm) { |
924 __ Push(StoreDescriptor::ReceiverRegister(), StoreDescriptor::NameRegister(), | 930 __ Push(StoreDescriptor::ReceiverRegister(), StoreDescriptor::NameRegister(), |
925 StoreDescriptor::ValueRegister()); | 931 StoreDescriptor::ValueRegister()); |
926 | 932 |
(...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1035 } else { | 1041 } else { |
1036 DCHECK(to_patch->Mask(TestBranchMask) == TBNZ); | 1042 DCHECK(to_patch->Mask(TestBranchMask) == TBNZ); |
1037 // This is JumpIfSmi(smi_reg, branch_imm). | 1043 // This is JumpIfSmi(smi_reg, branch_imm). |
1038 patcher.tbz(smi_reg, 0, branch_imm); | 1044 patcher.tbz(smi_reg, 0, branch_imm); |
1039 } | 1045 } |
1040 } | 1046 } |
1041 } | 1047 } |
1042 } // namespace v8::internal | 1048 } // namespace v8::internal |
1043 | 1049 |
1044 #endif // V8_TARGET_ARCH_ARM64 | 1050 #endif // V8_TARGET_ARCH_ARM64 |
OLD | NEW |