// Needed for cancelable steps. staticvolatile pthread_t reporter_thread_id;
void VMError::reporting_started() { // record pthread id of reporter thread.
reporter_thread_id = ::pthread_self();
}
void VMError::interrupt_reporting_thread() { // We misuse SIGILL here, but it does not really matter. We need // a signal which is handled by crash_handler and not likely to // occur during error reporting itself.
::pthread_kill(reporter_thread_id, SIGILL);
}
void VMError::install_secondary_signal_handler() { staticconstint signals_to_handle[] = {
SIGSEGV, SIGBUS, SIGILL, SIGFPE, SIGTRAP, 0// end
}; for (int i = 0; signals_to_handle[i] != 0; i++) { struct sigaction sigAct, oldSigAct;
PosixSignals::install_sigaction_signal_handler(&sigAct, &oldSigAct,
signals_to_handle[i], crash_handler); // No point checking the return code during error reporting.
}
}
// Write a hint to the stream in case siginfo relates to a segv/bus error // and the offending address points into CDS archive. void VMError::check_failing_cds_access(outputStream* st, constvoid* siginfo) { #if INCLUDE_CDS if (siginfo && UseSharedSpaces) { const siginfo_t* const si = (siginfo_t*)siginfo; if (si->si_signo == SIGBUS || si->si_signo == SIGSEGV) { constvoid* const fault_addr = si->si_addr; if (fault_addr != NULL) { if (MetaspaceShared::is_in_shared_metaspace(fault_addr)) {
st->print("Error accessing class data sharing archive. " "Mapped file inaccessible during execution, possible disk/network problem.");
}
}
}
} #endif
}
Messung V0.5 in Prozent
¤ Dauer der Verarbeitung: 0.16 Sekunden
(vorverarbeitet am 2026-06-10)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.