-
-
Notifications
You must be signed in to change notification settings - Fork 171
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
inproc: backtrace() on recent macOS no longer produces a stack-trace in the signal-handler #906
Comments
Hey @MeijisIrlnd would you be able to share a link to the event on Sentry, either here or via email to [email protected]? |
Related: #897 (comment) |
Hey, thanks for the quick response, link to the event on Sentry.io is here! So for initialisation, I'm using the JUCE framework, so my entry point is the constuctor of my AudioProcessor class - that calls this free function: void initSentry() {
auto* const options = sentry_options_new();
sentry_options_set_dsn(options, "https://mydsn.com");
// JUCE way to grab ~/Library/Aetherborne on mac and %APPDATA%/Aetherborne on windows
const auto appDataDir = juce::File::getSpecialLocation(juce::File::SpecialLocationType::userApplicationDataDirectory).getChildFile("Aetherborne");
const auto sentryDir = appDataDir.getChildFile(".sentry");
const auto path = sentryDir.getFullPathName().toStdString();
sentry_options_set_database_path(options, path.c_str());
const auto versionString = fmt::format("Aetherborne@{}", AETHERBORNE_VERSION);
sentry_options_set_release(options, versionString.c_str());
sentry_options_set_debug(options, 1);
// Saw another post mention this wasn't necessary, but thought I'd give it a try - same result with or without it
sentry_options_set_symbolize_stacktraces(options, 1);
sentry_init(options);
} Hope that helps, also had a look at @supervacuus 's linked post, maybe shipping with crashpad or breakpad is the way to go, but because this is going to be hosted within a different application, having an additional executable alongside our plugin can be a bit finnicky, hence us opting for inproc! |
@MeijisIrlnd, |
@supervacuus Oh my bad - I must have gotten it confused with |
Okay yeah - definitely much better with breakpad, here's that same nullptr deref crash taking down juce's plugin host, still not symbolising properly but I guess that's par for the course considering I don't have debug symbols for the host? - will experiment with it in Ableton and other hosts this evening in any case, thanks so much for your advice & the info! |
Yeah, this is an issue when adding crash reporting to the plugin rather than to the host: you depend on the host to be willing to share debug symbols. This is somewhat related to the topic here: #900 (comment). While you don't use Of course, the problem goes beyond runtime issues. It also concerns the availability of debug symbols: even if crash handling were centralized in the host, the symbolication of crashes would require access to the symbols of all plugins involved in the crash. There are solutions to these problems, but they need coordination between the host and plugin developers. |
Hi there, Is there any update on producing valid stack traces using inproc as a backend on macOS? I'm in a similar boat to @MeijisIrlnd. We are adding Sentry for crash reporting for a VST audio plugin running inside of a host digital audio workstation process. Breakpad produces stack traces correctly, but it does not reinstall the DAW's handler. So I believe we will end up breaking crash reporting for the DAW without forking Breakpad to reinstall existing handlers like inproc does. @MeijisIrlnd were you able to use Breakpad without stealing crash reports from the DAW? Thanks in advance! |
Hey @steve-mackinnon no update regarding inproc as of now, we'll keep this issue updated |
Hiya,
I've gotten sentry-native integrated into my VST3 / AU project, and managed to get super readable stack traces on Windows when the plugin crashes in a host by uploading the PDB debug symbols to the project with sentry-cli, which is great, (I temporarily made the callback from a mouseDown event just dereference a nullptr for testing) but on macOS (Ventura, M1 chip) with the same setup, (except DSYM files instead of PDBs), I end up with something along these lines:
Report Version: 104 Exception Type: Unknown (SIGILL) Application Specific Information: IllegalInstruction EOF
and this warning at the top of the issue page:
Wondering if I'm missing something super obvious here, I'm using the inproc backend to avoid having to ship extra files, and my setup is very minimal, literally just setting some options and calling
sentry_init
in my constructor, andsentry_shutdown
in my destructor,Let me know if you have any ideas of where to start looking or need more info!
The text was updated successfully, but these errors were encountered: