commit | 5bd31fbd56ef46f931b9ee4d80d8d17c2d6dc78c | [log] [tgz] |
---|---|---|
author | Martin Kustermann <kustermann@google.com> | Thu Jul 01 08:34:05 2021 +0000 |
committer | commit-bot@chromium.org <commit-bot@chromium.org> | Thu Jul 01 08:34:05 2021 +0000 |
tree | 1dc9c823b26b28b4f8cfee7aa0cfa8d5f2fb36ea | |
parent | ff4b86d2da8b54b102eb3e8306a005d976e150c7 [diff] |
[vm/concurrency] Avoid holding the program lock when installing new TTS When intalling a new TTS stub two fields have to be updated: - AbstractType::type_test_stub - AbstractType::type_test_stub_entry_point_ Right now the code takes the program lock when updating those two fields, which is very heavy weight, since this happens very often and therefore the lock will be contended. Instead we'll solve the write-write races by ensuring they are applied using atomics in (any) order - though ensuring that they will be in sync. It is fine for them to be out-of sync for a short time, as long as we're guaranteed that whenever we hit a gc safepoint they are in sync (because GC might collect old TTS stubs that are not referenced anymore - i.e. we need to avoid situations where the cached entrypoint is old but the code pointer is new) There can be multiple mutators computing and installing a TTS at the same time, they will try to install in sequence. => This reduces the average waiting time on write access to program lock by 3x Fixes https://github.com/dart-lang/sdk/issues/46124 Issue https://github.com/dart-lang/sdk/issues/46252 TEST=Existing test coverage. Change-Id: Id1ed29adeb26fa93494e8710206fd680d427bd34 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/205520 Commit-Queue: Martin Kustermann <kustermann@google.com> Reviewed-by: Slava Egorov <vegorov@google.com>
Dart is:
Optimized for UI: Develop with a programming language specialized around the needs of user interface creation.
Productive: Make changes iteratively: use hot reload to see the result instantly in your running app.
Fast on all platforms: Compile to ARM & x64 machine code for mobile, desktop, and backend. Or compile to JavaScript for the web.
Dart's flexible compiler technology lets you run Dart code in different ways, depending on your target platform and goals:
Dart Native: For programs targeting devices (mobile, desktop, server, and more), Dart Native includes both a Dart VM with JIT (just-in-time) compilation and an AOT (ahead-of-time) compiler for producing machine code.
Dart Web: For programs targeting the web, Dart Web includes both a development time compiler (dartdevc) and a production time compiler (dart2js).
Dart is free and open source.
See LICENSE and PATENT_GRANT.
Visit dart.dev to learn more about the language, tools, and to find codelabs.
Browse pub.dev for more packages and libraries contributed by the community and the Dart team.
Our API reference documentation is published at api.dart.dev, based on the stable release. (We also publish docs from our beta and dev channels, as well as from the primary development branch).
If you want to build Dart yourself, here is a guide to getting the source, preparing your machine to build the SDK, and building.
There are more documents on our wiki.
The easiest way to contribute to Dart is to file issues.
You can also contribute patches, as described in Contributing.