Index: src/x64/full-codegen-x64.cc |
diff --git a/src/x64/full-codegen-x64.cc b/src/x64/full-codegen-x64.cc |
index b0fa5cf003a6709c60854963c5fdb413f3692d52..d44fabbe3b7321c74f80384ad91789b3c597ba20 100644 |
--- a/src/x64/full-codegen-x64.cc |
+++ b/src/x64/full-codegen-x64.cc |
@@ -711,18 +711,24 @@ void FullCodeGenerator::EmitDeclaration(Variable* variable, |
} else if (prop != NULL) { |
if (function != NULL || mode == Variable::CONST) { |
// We are declaring a function or constant that rewrites to a |
- // property. Use (keyed) IC to set the initial value. |
- VisitForStackValue(prop->obj()); |
+ // property. Use (keyed) IC to set the initial value. We |
+ // cannot visit the rewrite because it's shared and we risk |
+ // recording duplicate AST IDs for bailouts from optimized code. |
+ ASSERT(prop->obj()->AsVariableProxy() != NULL); |
+ { AccumulatorValueContext for_object(this); |
+ EmitVariableLoad(prop->obj()->AsVariableProxy()->var()); |
+ } |
if (function != NULL) { |
- VisitForStackValue(prop->key()); |
+ __ push(rax); |
VisitForAccumulatorValue(function); |
- __ pop(rcx); |
+ __ pop(rdx); |
} else { |
- VisitForAccumulatorValue(prop->key()); |
- __ movq(rcx, result_register()); |
- __ LoadRoot(result_register(), Heap::kTheHoleValueRootIndex); |
+ __ movq(rdx, rax); |
+ __ LoadRoot(rax, Heap::kTheHoleValueRootIndex); |
} |
- __ pop(rdx); |
+ ASSERT(prop->key()->AsLiteral() != NULL && |
+ prop->key()->AsLiteral()->handle()->IsSmi()); |
+ __ Move(rcx, prop->key()->AsLiteral()->handle()); |
Handle<Code> ic(Builtins::builtin(Builtins::KeyedStoreIC_Initialize)); |
EmitCallIC(ic, RelocInfo::CODE_TARGET); |