-
Notifications
You must be signed in to change notification settings - Fork 12.9k
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
Better backtrace cleaning on panic #40201
Comments
I don't think we should too aggressively try to clean backtraces because we run the risk of hiding actually useful information. I'd be against capturing a backtrace at the beginning of tests/main/etc as that's somewhat surprising and we should otherwise be able to infer the bottom of the stack. I'd be fine just adding more heuristics. |
What do you mean by surprising? |
It's a pretty weighty piece of code to unconditionally run, it's also quite slow. We should avoid running it by default. |
Not wrong |
@Yamakaky |
No, that's what I meant. |
Correctly handles panics in threads and tests. First, the frames after `__rust_maybe_catch_panic` are discarded, then it uses a blacklist that does some more fine-tuning. Since frames after the call to `__rust_maybe_catch_panic` seem to be platform-independant, `BAD_PREFIXES_BOTTOM` could probably be cleaned a bit. Fixes rust-lang#40201
Followup of #38165.
The current behaviour is to maintain a blacklist of frames to remove from the backtrace. This poses problems in portability and accuracy. For example, the bottom of the backtrace is not cleaned when the panic is in a test or an other thread.
I propose that just before calling the user main/test/closure, the calling code would capture a backtrace. Then, on panic, the frames present is the backtrace pre and post panic would be removed. That way, no need to have a big whitelist. Some small post-processing may be needed to remove some additional frames.
A few questions:
__rust_maybe_catch_panic
used on all the platforms? If so, it could be used as a basis for this technique, since it's used for tests, the main thread and the secondary threads.The text was updated successfully, but these errors were encountered: