-
Notifications
You must be signed in to change notification settings - Fork 13k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Tooling for profiling of parallel code #7233
Comments
You may find some of the following pseudo-crates for logging useful. These could also be used as a basis for better facilities.
|
One simple way to achieve this is to provide decent debug info, which will enable us to integrate with advanced tools like vtune etc. Of course this won't be language specific. |
flip1995
pushed a commit
to flip1995/rust
that referenced
this issue
May 20, 2021
…_deref_coercion, r=flip1995 Fix a `manual_unwrap_or` FP with deref coercion Fix rust-lang/rust-clippy#7228. changelog: Fix a [`manual_unwrap_or`] FP with deref coercion
flip1995
added a commit
to flip1995/rust
that referenced
this issue
May 20, 2021
…=flip1995 Fix another manual_unwrap_or deref FP changelog: none (since this just piggybacks on rust-lang#7233) Fixes rust-lang#6960
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
A big goal when writing parallel code is that ... things run in parallel and go faster. But sometimes it is hard to tell whether or not the desired parallelism is occuring, and if it is not, it can be difficult to tell why it isn't there. Some sort of profiling tooling should exist to help programmers with this problem. An example of such a system is Haskell's ThreadScope, which provides a wealth of profiling information in a pleasing GUI interface. This is a very high bar for the long term, but in the short term there is stuff we can do.
The most basic useful output would be to allow a user to "watch" certain tasks, and receive an output of what times the tasks are active and on what threads. This could then be analyzed in another tool to see "how parallel" the code was. An example API would be to wrap "watched code" in a macro that expands to two debug print statements wrapping the code, with those debug statements printing scheduler id, timestamps, and a user-specified identifier to a log file.
I don't think much more should be planned for the short term, but awareness of a ThreadScope-like goal could influence scheduler design in minor ways.
http://www.haskell.org/haskellwiki/ThreadScope
The text was updated successfully, but these errors were encountered: