OLD | NEW |
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #include "vm/service_isolate.h" | 5 #include "vm/service_isolate.h" |
6 | 6 |
7 #include "vm/compiler.h" | 7 #include "vm/compiler.h" |
8 #include "vm/dart_api_impl.h" | 8 #include "vm/dart_api_impl.h" |
9 #include "vm/dart_entry.h" | 9 #include "vm/dart_entry.h" |
10 #include "vm/isolate.h" | 10 #include "vm/isolate.h" |
(...skipping 657 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
668 isolate->message_handler()->Run(Dart::thread_pool(), | 668 isolate->message_handler()->Run(Dart::thread_pool(), |
669 NULL, | 669 NULL, |
670 ShutdownIsolate, | 670 ShutdownIsolate, |
671 reinterpret_cast<uword>(isolate)); | 671 reinterpret_cast<uword>(isolate)); |
672 } | 672 } |
673 | 673 |
674 protected: | 674 protected: |
675 static void ShutdownIsolate(uword parameter) { | 675 static void ShutdownIsolate(uword parameter) { |
676 Isolate* I = reinterpret_cast<Isolate*>(parameter); | 676 Isolate* I = reinterpret_cast<Isolate*>(parameter); |
677 ASSERT(ServiceIsolate::IsServiceIsolate(I)); | 677 ASSERT(ServiceIsolate::IsServiceIsolate(I)); |
| 678 ServiceIsolate::SetServiceIsolate(NULL); |
| 679 ServiceIsolate::SetServicePort(ILLEGAL_PORT); |
678 { | 680 { |
679 // Print the error if there is one. This may execute dart code to | 681 // Print the error if there is one. This may execute dart code to |
680 // print the exception object, so we need to use a StartIsolateScope. | 682 // print the exception object, so we need to use a StartIsolateScope. |
681 StartIsolateScope start_scope(I); | 683 StartIsolateScope start_scope(I); |
682 Thread* T = Thread::Current(); | 684 Thread* T = Thread::Current(); |
683 ASSERT(I == T->isolate()); | 685 ASSERT(I == T->isolate()); |
684 StackZone zone(T); | 686 StackZone zone(T); |
685 HandleScope handle_scope(T); | 687 HandleScope handle_scope(T); |
686 Error& error = Error::Handle(Z); | 688 Error& error = Error::Handle(Z); |
687 error = I->object_store()->sticky_error(); | 689 error = I->object_store()->sticky_error(); |
688 if (!error.IsNull()) { | 690 if (!error.IsNull()) { |
689 OS::PrintErr("vm-service: Error: %s\n", error.ToErrorCString()); | 691 OS::PrintErr("vm-service: Error: %s\n", error.ToErrorCString()); |
690 } | 692 } |
691 Dart::RunShutdownCallback(); | 693 Dart::RunShutdownCallback(); |
692 } | 694 } |
693 { | 695 { |
694 // Shut the isolate down. | 696 // Shut the isolate down. |
695 SwitchIsolateScope switch_scope(I); | 697 SwitchIsolateScope switch_scope(I); |
696 Dart::ShutdownIsolate(); | 698 Dart::ShutdownIsolate(); |
697 } | 699 } |
698 ServiceIsolate::SetServiceIsolate(NULL); | |
699 ServiceIsolate::SetServicePort(ILLEGAL_PORT); | |
700 if (FLAG_trace_service) { | 700 if (FLAG_trace_service) { |
701 OS::Print("vm-service: Shutdown.\n"); | 701 OS::Print("vm-service: Shutdown.\n"); |
702 } | 702 } |
703 ServiceIsolate::FinishedExiting(); | 703 ServiceIsolate::FinishedExiting(); |
704 } | 704 } |
705 | 705 |
706 void RunMain(Isolate* I) { | 706 void RunMain(Isolate* I) { |
707 StartIsolateScope iso_scope(I); | 707 StartIsolateScope iso_scope(I); |
708 Thread* T = Thread::Current(); | 708 Thread* T = Thread::Current(); |
709 ASSERT(I == T->isolate()); | 709 ASSERT(I == T->isolate()); |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
755 ASSERT(monitor_ == NULL); | 755 ASSERT(monitor_ == NULL); |
756 monitor_ = new Monitor(); | 756 monitor_ = new Monitor(); |
757 ASSERT(monitor_ != NULL); | 757 ASSERT(monitor_ != NULL); |
758 // Grab the isolate create callback here to avoid race conditions with tests | 758 // Grab the isolate create callback here to avoid race conditions with tests |
759 // that change this after Dart_Initialize returns. | 759 // that change this after Dart_Initialize returns. |
760 create_callback_ = Isolate::CreateCallback(); | 760 create_callback_ = Isolate::CreateCallback(); |
761 Dart::thread_pool()->Run(new RunServiceTask()); | 761 Dart::thread_pool()->Run(new RunServiceTask()); |
762 } | 762 } |
763 | 763 |
764 | 764 |
| 765 void ServiceIsolate::KillServiceIsolate() { |
| 766 { |
| 767 MonitorLocker ml(monitor_); |
| 768 shutting_down_ = true; |
| 769 } |
| 770 Isolate::KillIfExists(isolate_); |
| 771 { |
| 772 MonitorLocker ml(monitor_); |
| 773 while (shutting_down_) { |
| 774 ml.Wait(); |
| 775 } |
| 776 } |
| 777 } |
| 778 |
| 779 |
765 void ServiceIsolate::Shutdown() { | 780 void ServiceIsolate::Shutdown() { |
766 if (!IsRunning()) { | 781 if (!IsRunning()) { |
| 782 if (isolate_ != NULL) { |
| 783 // TODO(johnmccutchan,turnidge) When it is possible to properly create |
| 784 // the VMService object and set up its shutdown handler in the service |
| 785 // isolate's main() function, this case will no longer be possible and |
| 786 // can be removed. |
| 787 KillServiceIsolate(); |
| 788 } |
767 return; | 789 return; |
768 } | 790 } |
769 { | 791 { |
770 MonitorLocker ml(monitor_); | 792 MonitorLocker ml(monitor_); |
771 shutting_down_ = true; | 793 shutting_down_ = true; |
772 } | 794 } |
773 SendServiceExitMessage(); | 795 SendServiceExitMessage(); |
774 { | 796 { |
775 MonitorLocker ml(monitor_); | 797 MonitorLocker ml(monitor_); |
776 while (shutting_down_ && (port_ != ILLEGAL_PORT)) { | 798 while (shutting_down_ && (port_ != ILLEGAL_PORT)) { |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
820 return result; | 842 return result; |
821 } | 843 } |
822 Dart_Handle source = GetSource(url_string); | 844 Dart_Handle source = GetSource(url_string); |
823 if (Dart_IsError(source)) { | 845 if (Dart_IsError(source)) { |
824 return source; | 846 return source; |
825 } | 847 } |
826 return Dart_LoadSource(library, url, source, 0, 0); | 848 return Dart_LoadSource(library, url, source, 0, 0); |
827 } | 849 } |
828 | 850 |
829 } // namespace dart | 851 } // namespace dart |
OLD | NEW |