| Index: src/ic/mips64/handler-compiler-mips64.cc
|
| diff --git a/src/ic/mips64/handler-compiler-mips64.cc b/src/ic/mips64/handler-compiler-mips64.cc
|
| index 2190f6d63e2c6812245c6698ffa15acc96655ead..282d5ac320759cd71d50dd560059b0f299357ed1 100644
|
| --- a/src/ic/mips64/handler-compiler-mips64.cc
|
| +++ b/src/ic/mips64/handler-compiler-mips64.cc
|
| @@ -473,8 +473,9 @@ Register PropertyHandlerCompiler::CheckPrototypes(
|
| NameDictionary::kNotFound);
|
|
|
| if (depth > 1) {
|
| - // TODO(jkummerow): Cache and re-use weak cell.
|
| - __ LoadWeakValue(reg, isolate()->factory()->NewWeakCell(current), miss);
|
| + Handle<WeakCell> weak_cell =
|
| + Map::GetOrCreatePrototypeWeakCell(current, isolate());
|
| + __ LoadWeakValue(reg, weak_cell, miss);
|
| }
|
| GenerateDictionaryNegativeLookup(masm(), miss, reg, name, scratch1,
|
| scratch2);
|
| @@ -493,7 +494,9 @@ Register PropertyHandlerCompiler::CheckPrototypes(
|
|
|
| bool return_holder = return_what == RETURN_HOLDER;
|
| if (return_holder && depth != 0) {
|
| - __ LoadWeakValue(reg, isolate()->factory()->NewWeakCell(current), miss);
|
| + Handle<WeakCell> weak_cell =
|
| + Map::GetOrCreatePrototypeWeakCell(current, isolate());
|
| + __ LoadWeakValue(reg, weak_cell, miss);
|
| }
|
|
|
| // Return the register containing the holder.
|
|
|