Index: src/lithium.cc |
diff --git a/src/lithium.cc b/src/lithium.cc |
index 43d690c0c74c827225ffd711970603d4f5ea538d..f840b7c13653d3404edfafc201802f309bad7f94 100644 |
--- a/src/lithium.cc |
+++ b/src/lithium.cc |
@@ -427,27 +427,23 @@ static void AddWeakObjectToCodeDependency(Isolate* isolate, |
void LChunk::RegisterWeakObjectsInOptimizedCode(Handle<Code> code) const { |
DCHECK(code->is_optimized_code()); |
ZoneList<Handle<Map> > maps(1, zone()); |
- ZoneList<Handle<JSObject> > objects(1, zone()); |
- ZoneList<Handle<Cell> > cells(1, zone()); |
+ ZoneList<Handle<HeapObject> > objects(1, zone()); |
int mode_mask = RelocInfo::ModeMask(RelocInfo::EMBEDDED_OBJECT) | |
RelocInfo::ModeMask(RelocInfo::CELL); |
for (RelocIterator it(*code, mode_mask); !it.done(); it.next()) { |
RelocInfo::Mode mode = it.rinfo()->rmode(); |
if (mode == RelocInfo::CELL && |
code->IsWeakObjectInOptimizedCode(it.rinfo()->target_cell())) { |
- Handle<Cell> cell(it.rinfo()->target_cell()); |
- cells.Add(cell, zone()); |
+ objects.Add(Handle<HeapObject>(it.rinfo()->target_cell()), zone()); |
} else if (mode == RelocInfo::EMBEDDED_OBJECT && |
code->IsWeakObjectInOptimizedCode(it.rinfo()->target_object())) { |
if (it.rinfo()->target_object()->IsMap()) { |
Handle<Map> map(Map::cast(it.rinfo()->target_object())); |
maps.Add(map, zone()); |
- } else if (it.rinfo()->target_object()->IsJSObject()) { |
- Handle<JSObject> object(JSObject::cast(it.rinfo()->target_object())); |
+ } else { |
+ Handle<HeapObject> object( |
+ HeapObject::cast(it.rinfo()->target_object())); |
objects.Add(object, zone()); |
- } else if (it.rinfo()->target_object()->IsCell()) { |
- Handle<Cell> cell(Cell::cast(it.rinfo()->target_object())); |
- cells.Add(cell, zone()); |
} |
} |
} |
@@ -457,9 +453,6 @@ void LChunk::RegisterWeakObjectsInOptimizedCode(Handle<Code> code) const { |
for (int i = 0; i < objects.length(); i++) { |
AddWeakObjectToCodeDependency(isolate(), objects.at(i), code); |
} |
- for (int i = 0; i < cells.length(); i++) { |
- AddWeakObjectToCodeDependency(isolate(), cells.at(i), code); |
- } |
if (FLAG_enable_ool_constant_pool) { |
code->constant_pool()->set_weak_object_state( |
ConstantPoolArray::WEAK_OBJECTS_IN_OPTIMIZED_CODE); |