| Index: runtime/vm/isolate.cc
|
| diff --git a/runtime/vm/isolate.cc b/runtime/vm/isolate.cc
|
| index f908b261d6a40c538c4c33220f1f7421669bf78a..5b262075a150036f7d5fa015d820b21a9ff963ec 100644
|
| --- a/runtime/vm/isolate.cc
|
| +++ b/runtime/vm/isolate.cc
|
| @@ -20,6 +20,8 @@
|
| #include "vm/message_handler.h"
|
| #include "vm/object_id_ring.h"
|
| #include "vm/object_store.h"
|
| +#include "vm/object.h"
|
| +#include "vm/os_thread.h"
|
| #include "vm/parser.h"
|
| #include "vm/port.h"
|
| #include "vm/profiler.h"
|
| @@ -31,7 +33,6 @@
|
| #include "vm/stub_code.h"
|
| #include "vm/symbols.h"
|
| #include "vm/tags.h"
|
| -#include "vm/os_thread.h"
|
| #include "vm/thread_interrupter.h"
|
| #include "vm/timer.h"
|
| #include "vm/visitor.h"
|
| @@ -493,6 +494,7 @@ Isolate::Isolate()
|
| tag_table_(GrowableObjectArray::null()),
|
| current_tag_(UserTag::null()),
|
| default_tag_(UserTag::null()),
|
| + deoptimized_code_array_(GrowableObjectArray::null()),
|
| metrics_list_head_(NULL),
|
| next_(NULL),
|
| REUSABLE_HANDLE_LIST(REUSABLE_HANDLE_INITIALIZERS)
|
| @@ -1251,6 +1253,10 @@ void Isolate::VisitObjectPointers(ObjectPointerVisitor* visitor,
|
| // Visit the tag table which is stored in the isolate.
|
| visitor->VisitPointer(reinterpret_cast<RawObject**>(&tag_table_));
|
|
|
| + // Visit the deoptimized code array which is stored in the isolate.
|
| + visitor->VisitPointer(
|
| + reinterpret_cast<RawObject**>(&deoptimized_code_array_));
|
| +
|
| // Visit objects in the debugger.
|
| debugger()->VisitObjectPointers(visitor);
|
|
|
| @@ -1448,6 +1454,25 @@ void Isolate::set_default_tag(const UserTag& tag) {
|
| }
|
|
|
|
|
| +void Isolate::set_deoptimized_code_array(const GrowableObjectArray& value) {
|
| + deoptimized_code_array_ = value.raw();
|
| +}
|
| +
|
| +
|
| +void Isolate::TrackDeoptimizedCode(const Code& code) {
|
| + ASSERT(!code.IsNull());
|
| + const GrowableObjectArray& deoptimized_code =
|
| + GrowableObjectArray::Handle(deoptimized_code_array());
|
| + if (deoptimized_code.IsNull()) {
|
| + // Not tracking deoptimized code.
|
| + return;
|
| + }
|
| + // TODO(johnmccutchan): Scan this array and the isolate's profile before
|
| + // old space GC and remove the keep_code flag.
|
| + deoptimized_code.Add(code);
|
| +}
|
| +
|
| +
|
| void Isolate::VisitIsolates(IsolateVisitor* visitor) {
|
| if (visitor == NULL) {
|
| return;
|
|
|