Index: src/mips/full-codegen-mips.cc |
diff --git a/src/mips/full-codegen-mips.cc b/src/mips/full-codegen-mips.cc |
index 2645bdd56ea4d823da437eb419548b6a99ab6091..eaf6414af739d249040608e2d48d0d57ae8b37bb 100644 |
--- a/src/mips/full-codegen-mips.cc |
+++ b/src/mips/full-codegen-mips.cc |
@@ -783,7 +783,7 @@ void FullCodeGenerator::EmitDeclaration(Variable* variable, |
// IDs for bailouts from optimized code. |
ASSERT(prop->obj()->AsVariableProxy() != NULL); |
{ AccumulatorValueContext for_object(this); |
- EmitVariableLoad(prop->obj()->AsVariableProxy()->var()); |
+ EmitVariableLoad(prop->obj()->AsVariableProxy()); |
} |
__ push(result_register()); |
@@ -1117,7 +1117,7 @@ void FullCodeGenerator::EmitNewClosure(Handle<SharedFunctionInfo> info, |
void FullCodeGenerator::VisitVariableProxy(VariableProxy* expr) { |
Comment cmnt(masm_, "[ VariableProxy"); |
- EmitVariableLoad(expr->var()); |
+ EmitVariableLoad(expr); |
} |
@@ -1262,7 +1262,11 @@ void FullCodeGenerator::EmitDynamicLoadFromSlotFastCase( |
} |
-void FullCodeGenerator::EmitVariableLoad(Variable* var) { |
+void FullCodeGenerator::EmitVariableLoad(VariableProxy* proxy) { |
+ // Record position before possible IC call. |
+ SetSourcePosition(proxy->position()); |
+ Variable* var = proxy->var(); |
+ |
// Three cases: non-this global variables, lookup slots, and all other |
// types of slots. |
Slot* slot = var->AsSlot(); |
@@ -1598,7 +1602,7 @@ void FullCodeGenerator::VisitAssignment(Assignment* expr) { |
{ AccumulatorValueContext context(this); |
switch (assign_type) { |
case VARIABLE: |
- EmitVariableLoad(expr->target()->AsVariableProxy()->var()); |
+ EmitVariableLoad(expr->target()->AsVariableProxy()); |
PrepareForBailout(expr->target(), TOS_REG); |
break; |
case NAMED_PROPERTY: |
@@ -3839,7 +3843,7 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) { |
if (assign_type == VARIABLE) { |
ASSERT(expr->expression()->AsVariableProxy()->var() != NULL); |
AccumulatorValueContext context(this); |
- EmitVariableLoad(expr->expression()->AsVariableProxy()->var()); |
+ EmitVariableLoad(expr->expression()->AsVariableProxy()); |
} else { |
// Reserve space for result of postfix operation. |
if (expr->is_postfix() && !context()->IsEffect()) { |