Index: src/ia32/ic-ia32.cc |
diff --git a/src/ia32/ic-ia32.cc b/src/ia32/ic-ia32.cc |
index 4106f0108903bde9f0cb9cef50f06bbb671ee3c2..1e77a78deac3d740030970d8e69eb6bb37ca05fb 100644 |
--- a/src/ia32/ic-ia32.cc |
+++ b/src/ia32/ic-ia32.cc |
@@ -97,60 +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 |r0|. 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; |
- __ mov(r1, FieldOperand(elements, kCapacityOffset)); |
- __ shr(r1, kSmiTagSize); // convert smi to int |
- __ dec(r1); |
- |
- // 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. |
- __ mov(r0, FieldOperand(name, String::kHashFieldOffset)); |
- __ shr(r0, String::kHashShift); |
- if (i > 0) { |
- __ add(Operand(r0), Immediate(StringDictionary::GetProbeOffset(i))); |
- } |
- __ and_(r0, Operand(r1)); |
- |
- // Scale the index by multiplying by the entry size. |
- ASSERT(StringDictionary::kEntrySize == 3); |
- __ lea(r0, Operand(r0, r0, times_2, 0)); // r0 = r0 * 3 |
- |
- // Check if the key is identical to the name. |
- __ cmp(name, Operand(elements, r0, times_4, |
- kElementsStartOffset - kHeapObjectTag)); |
- if (i != kProbes - 1) { |
- __ j(equal, done, taken); |
- } else { |
- __ j(not_equal, miss, not_taken); |
- } |
- } |
-} |
- |
- |
// Helper function used to load a property from a dictionary backing |
// storage. This function may fail to load a property even though it is |
@@ -183,13 +129,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 |
@@ -238,13 +184,13 @@ static void GenerateDictionaryStore(MacroAssembler* masm, |
// 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 |