| Index: runtime/vm/thread_interrupter_win.cc | 
| diff --git a/runtime/vm/thread_interrupter_win.cc b/runtime/vm/thread_interrupter_win.cc | 
| index 1bfd84f78bc501896064a641709e70d5fec0e0b6..70a5e8c93f877bc049eef271a4c32bae48bdf558 100644 | 
| --- a/runtime/vm/thread_interrupter_win.cc | 
| +++ b/runtime/vm/thread_interrupter_win.cc | 
| @@ -51,57 +51,55 @@ class ThreadInterrupterWin : public AllStatic { | 
| } | 
|  | 
|  | 
| -  static void Interrupt(InterruptableThreadState* state) { | 
| -    ASSERT(!OSThread::Compare(GetCurrentThreadId(), state->id)); | 
| +  static void Interrupt(Thread* thread) { | 
| +    ASSERT(!OSThread::Compare(GetCurrentThreadId(), thread->id())); | 
| HANDLE handle = OpenThread(THREAD_GET_CONTEXT | | 
| THREAD_QUERY_INFORMATION | | 
| THREAD_SUSPEND_RESUME, | 
| false, | 
| -                               state->id); | 
| +                               thread->id()); | 
| ASSERT(handle != NULL); | 
| DWORD result = SuspendThread(handle); | 
| if (result == kThreadError) { | 
| if (FLAG_trace_thread_interrupter) { | 
| -        OS::Print("ThreadInterrupted failed to suspend thread %p\n", | 
| -                  reinterpret_cast<void*>(state->id)); | 
| +        OS::Print("ThreadInterrupter failed to suspend thread %p\n", | 
| +                  reinterpret_cast<void*>(thread->id())); | 
| } | 
| CloseHandle(handle); | 
| return; | 
| } | 
| InterruptedThreadState its; | 
| -    its.tid = state->id; | 
| +    its.tid = thread->id(); | 
| if (!GrabRegisters(handle, &its)) { | 
| // Failed to get thread registers. | 
| ResumeThread(handle); | 
| if (FLAG_trace_thread_interrupter) { | 
| -        OS::Print("ThreadInterrupted failed to get registers for %p\n", | 
| -                  reinterpret_cast<void*>(state->id)); | 
| +        OS::Print("ThreadInterrupter failed to get registers for %p\n", | 
| +                  reinterpret_cast<void*>(thread->id())); | 
| } | 
| CloseHandle(handle); | 
| return; | 
| } | 
| -    if (state->callback == NULL) { | 
| -      // No callback registered. | 
| -      ResumeThread(handle); | 
| -      CloseHandle(handle); | 
| -      return; | 
| +    ThreadInterruptCallback callback = NULL; | 
| +    void* callback_data = NULL; | 
| +    if (thread->IsThreadInterrupterEnabled(&callback, &callback_data)) { | 
| +      callback(its, callback_data); | 
| } | 
| -    state->callback(its, state->data); | 
| ResumeThread(handle); | 
| CloseHandle(handle); | 
| } | 
| }; | 
|  | 
|  | 
| -void ThreadInterrupter::InterruptThread(InterruptableThreadState* state) { | 
| +void ThreadInterrupter::InterruptThread(Thread* thread) { | 
| if (FLAG_trace_thread_interrupter) { | 
| OS::Print("ThreadInterrupter suspending %p\n", | 
| -              reinterpret_cast<void*>(state->id)); | 
| +              reinterpret_cast<void*>(thread->id())); | 
| } | 
| -  ThreadInterrupterWin::Interrupt(state); | 
| +  ThreadInterrupterWin::Interrupt(thread); | 
| if (FLAG_trace_thread_interrupter) { | 
| OS::Print("ThreadInterrupter resuming %p\n", | 
| -              reinterpret_cast<void*>(state->id)); | 
| +              reinterpret_cast<void*>(thread->id())); | 
| } | 
| } | 
|  | 
|  |