| Index: src/lithium-codegen.cc
|
| diff --git a/src/lithium-codegen.cc b/src/lithium-codegen.cc
|
| index ad566168e7280f7e2dae82f68c80ebe66be7b49c..f2b67ab088e77695647bed7d9f92c6b82c7ce84e 100644
|
| --- a/src/lithium-codegen.cc
|
| +++ b/src/lithium-codegen.cc
|
| @@ -150,4 +150,34 @@ int LCodeGenBase::GetNextEmittedBlock() const {
|
| }
|
|
|
|
|
| +void LCodeGenBase::RegisterDependentCodeForEmbeddedMaps(Handle<Code> code) {
|
| + ZoneList<Handle<Map> > maps(1, zone());
|
| + ZoneList<Handle<JSObject> > objects(1, zone());
|
| + int mode_mask = RelocInfo::ModeMask(RelocInfo::EMBEDDED_OBJECT);
|
| + for (RelocIterator it(*code, mode_mask); !it.done(); it.next()) {
|
| + if (Code::IsWeakEmbeddedObject(code->kind(), 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()));
|
| + objects.Add(object, zone());
|
| + }
|
| + }
|
| + }
|
| +#ifdef VERIFY_HEAP
|
| + // This disables verification of weak embedded objects after full GC.
|
| + // AddDependentCode can cause a GC, which would observe the state where
|
| + // this code is not yet in the depended code lists of the embedded maps.
|
| + NoWeakObjectVerificationScope disable_verification_of_embedded_objects;
|
| +#endif
|
| + for (int i = 0; i < maps.length(); i++) {
|
| + maps.at(i)->AddDependentCode(DependentCode::kWeaklyEmbeddedGroup, code);
|
| + }
|
| + for (int i = 0; i < objects.length(); i++) {
|
| + AddWeakObjectToCodeDependency(isolate()->heap(), objects.at(i), code);
|
| + }
|
| +}
|
| +
|
| +
|
| } } // namespace v8::internal
|
|
|