Index: src/ic/ia32/handler-compiler-ia32.cc |
diff --git a/src/ic/ia32/handler-compiler-ia32.cc b/src/ic/ia32/handler-compiler-ia32.cc |
index 8f5200aee63b8d4f119e97eabf75d33bd38efd19..57a478e66435e41af1dde0d60aa4db40890d6f13 100644 |
--- a/src/ic/ia32/handler-compiler-ia32.cc |
+++ b/src/ic/ia32/handler-compiler-ia32.cc |
@@ -14,6 +14,39 @@ |
namespace internal { |
#define __ ACCESS_MASM(masm) |
+ |
+ |
+static void LoadIC_PushArgs(MacroAssembler* masm) { |
+ Register receiver = LoadDescriptor::ReceiverRegister(); |
+ Register name = LoadDescriptor::NameRegister(); |
+ |
+ DCHECK(!ebx.is(receiver) && !ebx.is(name)); |
+ |
+ __ pop(ebx); |
+ __ push(receiver); |
+ __ push(name); |
+ __ push(ebx); |
+} |
+ |
+ |
+void NamedLoadHandlerCompiler::GenerateSlow(MacroAssembler* masm) { |
+ // Return address is on the stack. |
+ LoadIC_PushArgs(masm); |
+ |
+ // Do tail-call to runtime routine. |
+ ExternalReference ref(IC_Utility(IC::kLoadIC_Slow), masm->isolate()); |
+ __ TailCallExternalReference(ref, 2, 1); |
+} |
+ |
+ |
+void ElementHandlerCompiler::GenerateLoadSlow(MacroAssembler* masm) { |
+ // Return address is on the stack. |
+ LoadIC_PushArgs(masm); |
+ |
+ // Do tail-call to runtime routine. |
+ ExternalReference ref(IC_Utility(IC::kKeyedLoadIC_Slow), masm->isolate()); |
+ __ TailCallExternalReference(ref, 2, 1); |
+} |
void NamedLoadHandlerCompiler::GenerateLoadViaGetter( |