diff --git a/src/hotspot/os/posix/signals_posix.cpp b/src/hotspot/os/posix/signals_posix.cpp index 895c3cc09ae..6e94b47712f 100644 --- a/src/hotspot/os/posix/signals_posix.cpp +++ b/src/hotspot/os/posix/signals_posix.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2020, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1556,8 +1556,6 @@ void PosixSignals::hotspot_sigmask(Thread* thread) { // - Forte Analyzer: AsyncGetCallTrace() // - StackBanging: get_frame_at_stack_banging_point() -sigset_t SR_sigset; - static void resume_clear_context(OSThread *osthread) { osthread->set_ucontext(NULL); osthread->set_siginfo(NULL); @@ -1673,14 +1671,11 @@ int SR_initialize() { assert(PosixSignals::SR_signum > SIGSEGV && PosixSignals::SR_signum > SIGBUS, "SR_signum must be greater than max(SIGSEGV, SIGBUS), see 4355769"); - sigemptyset(&SR_sigset); - sigaddset(&SR_sigset, PosixSignals::SR_signum); - // Set up signal handler for suspend/resume act.sa_flags = SA_RESTART|SA_SIGINFO; act.sa_handler = (void (*)(int)) SR_handler; - // SR_signum is blocked by default. + // SR_signum is blocked when the handler runs. pthread_sigmask(SIG_BLOCK, NULL, &act.sa_mask); remove_error_signals_from_set(&(act.sa_mask));