OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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 "include/dart_api.h" | 5 #include "include/dart_api.h" |
6 #include "include/dart_mirrors_api.h" | 6 #include "include/dart_mirrors_api.h" |
7 #include "include/dart_native_api.h" | 7 #include "include/dart_native_api.h" |
8 | 8 |
9 #include "platform/assert.h" | 9 #include "platform/assert.h" |
10 #include "vm/class_finalizer.h" | 10 #include "vm/class_finalizer.h" |
(...skipping 1347 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1358 | 1358 |
1359 | 1359 |
1360 DART_EXPORT Dart_Isolate Dart_CreateIsolate(const char* script_uri, | 1360 DART_EXPORT Dart_Isolate Dart_CreateIsolate(const char* script_uri, |
1361 const char* main, | 1361 const char* main, |
1362 const uint8_t* snapshot, | 1362 const uint8_t* snapshot, |
1363 Dart_IsolateFlags* flags, | 1363 Dart_IsolateFlags* flags, |
1364 void* callback_data, | 1364 void* callback_data, |
1365 char** error) { | 1365 char** error) { |
1366 CHECK_NO_ISOLATE(Isolate::Current()); | 1366 CHECK_NO_ISOLATE(Isolate::Current()); |
1367 char* isolate_name = BuildIsolateName(script_uri, main); | 1367 char* isolate_name = BuildIsolateName(script_uri, main); |
1368 Thread::EnsureInit(); | |
1369 | 1368 |
1370 // Setup default flags in case none were passed. | 1369 // Setup default flags in case none were passed. |
1371 Dart_IsolateFlags api_flags; | 1370 Dart_IsolateFlags api_flags; |
1372 if (flags == NULL) { | 1371 if (flags == NULL) { |
1373 Isolate::Flags vm_flags; | 1372 Isolate::Flags vm_flags; |
1374 vm_flags.CopyTo(&api_flags); | 1373 vm_flags.CopyTo(&api_flags); |
1375 flags = &api_flags; | 1374 flags = &api_flags; |
1376 } | 1375 } |
1377 Isolate* I = Dart::CreateIsolate(isolate_name, *flags); | 1376 Isolate* I = Dart::CreateIsolate(isolate_name, *flags); |
1378 free(isolate_name); | 1377 free(isolate_name); |
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1452 | 1451 |
1453 | 1452 |
1454 | 1453 |
1455 DART_EXPORT void Dart_EnterIsolate(Dart_Isolate isolate) { | 1454 DART_EXPORT void Dart_EnterIsolate(Dart_Isolate isolate) { |
1456 CHECK_NO_ISOLATE(Isolate::Current()); | 1455 CHECK_NO_ISOLATE(Isolate::Current()); |
1457 // TODO(16615): Validate isolate parameter. | 1456 // TODO(16615): Validate isolate parameter. |
1458 Isolate* iso = reinterpret_cast<Isolate*>(isolate); | 1457 Isolate* iso = reinterpret_cast<Isolate*>(isolate); |
1459 if (iso->HasMutatorThread()) { | 1458 if (iso->HasMutatorThread()) { |
1460 FATAL("Multiple mutators within one isolate is not supported."); | 1459 FATAL("Multiple mutators within one isolate is not supported."); |
1461 } | 1460 } |
1462 Thread::EnsureInit(); | |
1463 Thread::EnterIsolate(iso); | 1461 Thread::EnterIsolate(iso); |
1464 } | 1462 } |
1465 | 1463 |
1466 | 1464 |
1467 DART_EXPORT void Dart_ThreadDisableProfiling() { | 1465 DART_EXPORT void Dart_ThreadDisableProfiling() { |
1468 Thread* T = Thread::Current(); | 1466 OSThread* os_thread = OSThread::Current(); |
1469 if (T == NULL) { | 1467 if (os_thread == NULL) { |
1470 return; | 1468 return; |
1471 } | 1469 } |
1472 T->DisableThreadInterrupts(); | 1470 os_thread->DisableThreadInterrupts(); |
1473 } | 1471 } |
1474 | 1472 |
1475 | 1473 |
1476 DART_EXPORT void Dart_ThreadEnableProfiling() { | 1474 DART_EXPORT void Dart_ThreadEnableProfiling() { |
1477 Thread* T = Thread::Current(); | 1475 OSThread* os_thread = OSThread::Current(); |
1478 if (T == NULL) { | 1476 if (os_thread == NULL) { |
1479 return; | 1477 return; |
1480 } | 1478 } |
1481 T->EnableThreadInterrupts(); | 1479 os_thread->EnableThreadInterrupts(); |
1482 } | 1480 } |
1483 | 1481 |
1484 | 1482 |
1485 DART_EXPORT void Dart_ExitIsolate() { | 1483 DART_EXPORT void Dart_ExitIsolate() { |
1486 CHECK_ISOLATE(Isolate::Current()); | 1484 CHECK_ISOLATE(Isolate::Current()); |
1487 Thread::ExitIsolate(); | 1485 Thread::ExitIsolate(); |
1488 } | 1486 } |
1489 | 1487 |
1490 | 1488 |
1491 // TODO(iposva): Remove this API and instead expose the underlying flags. | 1489 // TODO(iposva): Remove this API and instead expose the underlying flags. |
(...skipping 4596 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
6088 ApiReallocate); | 6086 ApiReallocate); |
6089 writer.WriteFullSnapshot(); | 6087 writer.WriteFullSnapshot(); |
6090 *vm_isolate_snapshot_size = writer.VmIsolateSnapshotSize(); | 6088 *vm_isolate_snapshot_size = writer.VmIsolateSnapshotSize(); |
6091 *isolate_snapshot_size = writer.IsolateSnapshotSize(); | 6089 *isolate_snapshot_size = writer.IsolateSnapshotSize(); |
6092 *instructions_snapshot_size = writer.InstructionsSnapshotSize(); | 6090 *instructions_snapshot_size = writer.InstructionsSnapshotSize(); |
6093 | 6091 |
6094 return Api::Success(); | 6092 return Api::Success(); |
6095 } | 6093 } |
6096 | 6094 |
6097 } // namespace dart | 6095 } // namespace dart |
OLD | NEW |