Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(499)

Unified Diff: runtime/vm/cha.cc

Issue 463103002: Fix bug with CHA dependencies by recording a set of classes for registering code. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: runtime/vm/cha.cc
===================================================================
--- runtime/vm/cha.cc (revision 39070)
+++ runtime/vm/cha.cc (working copy)
@@ -12,11 +12,21 @@
namespace dart {
+void CHA::AddToCHAClasses(Class* cls) {
+ for (intptr_t i = 0; i < cha_classes_.length(); i++) {
+ if (cha_classes_[i]->raw() == cls->raw()) {
+ return;
+ }
+ }
+ cha_classes_.Add(cls);
+}
+
Vyacheslav Egorov (Google) 2014/08/12 12:16:55 add empty line
Florian Schneider 2014/08/13 10:34:40 Done.
bool CHA::HasSubclasses(intptr_t cid) {
- Isolate* isolate = Isolate::Current();
const bool has_subclasses = HasSubclassesSafe(cid);
if (!has_subclasses) {
- isolate->set_cha_used(true);
+ const ClassTable& class_table = *isolate_->class_table();
+ Class& cls = Class::ZoneHandle(isolate_, class_table.At(cid));
+ AddToCHAClasses(&cls);
}
return has_subclasses;
}
@@ -24,69 +34,23 @@
bool CHA::HasSubclassesSafe(intptr_t cid) {
Vyacheslav Egorov (Google) 2014/08/12 12:16:55 I find the name HasSubclassesSafe confusing.
Florian Schneider 2014/08/13 10:34:40 I removed it.
ASSERT(cid >= kInstanceCid);
- Isolate* isolate = Isolate::Current();
- const ClassTable& class_table = *isolate->class_table();
- const Class& cls = Class::Handle(isolate, class_table.At(cid));
+ const ClassTable& class_table = *isolate_->class_table();
+ const Class& cls = Class::Handle(isolate_, class_table.At(cid));
ASSERT(!cls.IsNull());
if (cls.IsObjectClass()) {
// Class Object has subclasses, although we do not keep track of them.
return true;
}
const GrowableObjectArray& cls_direct_subclasses =
- GrowableObjectArray::Handle(isolate, cls.direct_subclasses());
- return
- !cls_direct_subclasses.IsNull() && (cls_direct_subclasses.Length() > 0);
+ GrowableObjectArray::Handle(isolate_, cls.direct_subclasses());
+ return !cls_direct_subclasses.IsNull()
+ && (cls_direct_subclasses.Length() > 0);
}
-// Returns true if the given array of cids contains the given cid.
-static bool ContainsCid(ZoneGrowableArray<intptr_t>* cids, intptr_t cid) {
- for (intptr_t i = 0; i < cids->length(); i++) {
- if ((*cids)[i] == cid) {
- return true;
- }
- }
- return false;
-}
-
-
-// Recursively collect direct and indirect subclass ids of cls.
-static void CollectSubclassIds(ZoneGrowableArray<intptr_t>* cids,
- const Class& cls) {
- const GrowableObjectArray& cls_direct_subclasses =
- GrowableObjectArray::Handle(cls.direct_subclasses());
- if (cls_direct_subclasses.IsNull()) {
- return;
- }
- Class& direct_subclass = Class::Handle();
- for (intptr_t i = 0; i < cls_direct_subclasses.Length(); i++) {
- direct_subclass ^= cls_direct_subclasses.At(i);
- intptr_t direct_subclass_id = direct_subclass.id();
- if (!ContainsCid(cids, direct_subclass_id)) {
- cids->Add(direct_subclass_id);
- CollectSubclassIds(cids, direct_subclass);
- }
- }
-}
-
-
-ZoneGrowableArray<intptr_t>* CHA::GetSubclassIdsOf(intptr_t cid) {
- ASSERT(cid > kInstanceCid);
- Isolate* isolate = Isolate::Current();
- const ClassTable& class_table = *isolate->class_table();
- const Class& cls = Class::Handle(isolate, class_table.At(cid));
- ASSERT(!cls.IsNull());
- ZoneGrowableArray<intptr_t>* ids = new ZoneGrowableArray<intptr_t>();
- CollectSubclassIds(ids, cls);
- isolate->set_cha_used(true);
- return ids;
-}
-
-
bool CHA::HasOverride(const Class& cls, const String& function_name) {
- Isolate* isolate = Isolate::Current();
const GrowableObjectArray& cls_direct_subclasses =
- GrowableObjectArray::Handle(isolate, cls.direct_subclasses());
+ GrowableObjectArray::Handle(isolate_, cls.direct_subclasses());
// Subclasses of Object are not tracked by CHA. Safely assume that overrides
// exist.
if (cls.IsObjectClass()) {
@@ -94,10 +58,10 @@
}
if (cls_direct_subclasses.IsNull()) {
- isolate->set_cha_used(true);
+ AddToCHAClasses(&Class::ZoneHandle(cls.raw()));
Vyacheslav Egorov (Google) 2014/08/12 12:16:55 Maybe it's better to have a single return false in
return false;
}
- Class& direct_subclass = Class::Handle(isolate);
+ Class& direct_subclass = Class::Handle(isolate_);
for (intptr_t i = 0; i < cls_direct_subclasses.Length(); i++) {
direct_subclass ^= cls_direct_subclasses.At(i);
// Unfinalized classes are treated as non-existent for CHA purposes,
@@ -111,44 +75,8 @@
return true;
}
}
- isolate->set_cha_used(true);
+ AddToCHAClasses(&Class::ZoneHandle(cls.raw()));
return false;
}
-
-ZoneGrowableArray<Function*>* CHA::GetNamedInstanceFunctionsOf(
- const ZoneGrowableArray<intptr_t>& cids,
- const String& function_name) {
- Isolate* isolate = Isolate::Current();
- ASSERT(!function_name.IsNull());
- const ClassTable& class_table = *isolate->class_table();
- ZoneGrowableArray<Function*>* functions = new ZoneGrowableArray<Function*>();
- Class& cls = Class::Handle(isolate);
- Function& cls_function = Function::Handle(isolate);
- for (intptr_t i = 0; i < cids.length(); i++) {
- const intptr_t cid = cids[i];
- ASSERT(cid > kInstanceCid);
- cls = class_table.At(cid);
- cls_function = cls.LookupDynamicFunction(function_name);
- if (!cls_function.IsNull()) {
- functions->Add(&Function::ZoneHandle(isolate, cls_function.raw()));
- }
- }
- isolate->set_cha_used(true);
- return functions;
-}
-
-
-ZoneGrowableArray<Function*>* CHA::GetOverridesOf(const Function& function) {
- ASSERT(!function.IsNull());
- ASSERT(function.IsDynamicFunction());
- Isolate* isolate = Isolate::Current();
- const Class& function_owner = Class::Handle(isolate, function.Owner());
- const String& function_name = String::Handle(isolate, function.name());
- ZoneGrowableArray<intptr_t>* cids = new ZoneGrowableArray<intptr_t>();
- CollectSubclassIds(cids, function_owner);
- isolate->set_cha_used(true);
- return GetNamedInstanceFunctionsOf(*cids, function_name);
-}
-
} // namespace dart

Powered by Google App Engine
This is Rietveld 408576698