Index: src/x64/ic-x64.cc |
diff --git a/src/x64/ic-x64.cc b/src/x64/ic-x64.cc |
index 5ed89b5d4ddd37b184876b4e05e4766fd7c5eb6c..93307bab7b603a481e812407470f46f5cae2e479 100644 |
--- a/src/x64/ic-x64.cc |
+++ b/src/x64/ic-x64.cc |
@@ -97,58 +97,6 @@ static void GenerateStringDictionaryReceiverCheck(MacroAssembler* masm, |
} |
-// Probe the string dictionary in the |elements| register. Jump to the |
-// |done| label if a property with the given name is found leaving the |
-// index into the dictionary in |r1|. Jump to the |miss| label |
-// otherwise. |
-static void GenerateStringDictionaryProbes(MacroAssembler* masm, |
- Label* miss, |
- Label* done, |
- Register elements, |
- Register name, |
- Register r0, |
- Register r1) { |
- // Assert that name contains a string. |
- if (FLAG_debug_code) __ AbortIfNotString(name); |
- |
- // Compute the capacity mask. |
- const int kCapacityOffset = |
- StringDictionary::kHeaderSize + |
- StringDictionary::kCapacityIndex * kPointerSize; |
- __ SmiToInteger32(r0, FieldOperand(elements, kCapacityOffset)); |
- __ decl(r0); |
- |
- // Generate an unrolled loop that performs a few probes before |
- // giving up. Measurements done on Gmail indicate that 2 probes |
- // cover ~93% of loads from dictionaries. |
- static const int kProbes = 4; |
- const int kElementsStartOffset = |
- StringDictionary::kHeaderSize + |
- StringDictionary::kElementsStartIndex * kPointerSize; |
- for (int i = 0; i < kProbes; i++) { |
- // Compute the masked index: (hash + i + i * i) & mask. |
- __ movl(r1, FieldOperand(name, String::kHashFieldOffset)); |
- __ shrl(r1, Immediate(String::kHashShift)); |
- if (i > 0) { |
- __ addl(r1, Immediate(StringDictionary::GetProbeOffset(i))); |
- } |
- __ and_(r1, r0); |
- |
- // Scale the index by multiplying by the entry size. |
- ASSERT(StringDictionary::kEntrySize == 3); |
- __ lea(r1, Operand(r1, r1, times_2, 0)); // r1 = r1 * 3 |
- |
- // Check if the key is identical to the name. |
- __ cmpq(name, Operand(elements, r1, times_pointer_size, |
- kElementsStartOffset - kHeapObjectTag)); |
- if (i != kProbes - 1) { |
- __ j(equal, done); |
- } else { |
- __ j(not_equal, miss); |
- } |
- } |
-} |
- |
// Helper function used to load a property from a dictionary backing storage. |
// This function may return false negatives, so miss_label |
@@ -179,13 +127,13 @@ static void GenerateDictionaryLoad(MacroAssembler* masm, |
Label done; |
// Probe the dictionary. |
- GenerateStringDictionaryProbes(masm, |
- miss_label, |
- &done, |
- elements, |
- name, |
- r0, |
- r1); |
+ StringDictionaryLookupStub::GeneratePositiveLookup(masm, |
+ miss_label, |
+ &done, |
+ elements, |
+ name, |
+ r0, |
+ r1); |
// If probing finds an entry in the dictionary, r0 contains the |
// index into the dictionary. Check that the value is a normal |
@@ -237,13 +185,13 @@ static void GenerateDictionaryStore(MacroAssembler* masm, |
Label done; |
// Probe the dictionary. |
- GenerateStringDictionaryProbes(masm, |
- miss_label, |
- &done, |
- elements, |
- name, |
- scratch0, |
- scratch1); |
+ StringDictionaryLookupStub::GeneratePositiveLookup(masm, |
+ miss_label, |
+ &done, |
+ elements, |
+ name, |
+ scratch0, |
+ scratch1); |
// If probing finds an entry in the dictionary, scratch0 contains the |
// index into the dictionary. Check that the value is a normal |