| Index: src/compiler.cc
|
| diff --git a/src/compiler.cc b/src/compiler.cc
|
| index 055777af77db2118a08e06d68cb7e798535dc4e6..2db67b9e005fd62ffbaab7a0789aa355d4877575 100644
|
| --- a/src/compiler.cc
|
| +++ b/src/compiler.cc
|
| @@ -286,9 +286,14 @@ void AddWeakObjectToCodeDependency(Isolate* isolate, Handle<HeapObject> object,
|
| Handle<Code> code) {
|
| Handle<WeakCell> cell = Code::WeakCellFor(code);
|
| Heap* heap = isolate->heap();
|
| - Handle<DependentCode> dep(heap->LookupWeakObjectToCodeDependency(object));
|
| - dep = DependentCode::InsertWeakCode(dep, DependentCode::kWeakCodeGroup, cell);
|
| - heap->AddWeakObjectToCodeDependency(object, dep);
|
| + if (heap->InNewSpace(*object)) {
|
| + heap->AddWeakNewSpaceObjectToCodeDependency(object, cell);
|
| + } else {
|
| + Handle<DependentCode> dep(heap->LookupWeakObjectToCodeDependency(object));
|
| + dep =
|
| + DependentCode::InsertWeakCode(dep, DependentCode::kWeakCodeGroup, cell);
|
| + heap->AddWeakObjectToCodeDependency(object, dep);
|
| + }
|
| }
|
|
|
| } // namespace
|
|
|