signals-state-save-restore.h 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. /* Copyright (C) 2016-2022 Free Software Foundation, Inc.
  2. This file is part of GDB.
  3. This program is free software; you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation; either version 3 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>. */
  13. #ifndef COMMON_SIGNALS_STATE_SAVE_RESTORE_H
  14. #define COMMON_SIGNALS_STATE_SAVE_RESTORE_H
  15. /* Save/restore the signal actions of all signals, and the signal
  16. mask.
  17. Since the exec family of functions does not reset the signal
  18. disposition of signals set to SIG_IGN, nor does it reset the signal
  19. mask, in order to be transparent, when spawning new child processes
  20. to debug (with "run", etc.), we must reset signal actions and mask
  21. back to what was originally inherited from gdb/gdbserver's parent,
  22. just before execing the target program to debug. */
  23. /* Save the signal state of all signals. If !QUIET, warn if we detect
  24. a custom signal handler preinstalled. */
  25. extern void save_original_signals_state (bool quiet);
  26. /* Restore the signal state of all signals. */
  27. extern void restore_original_signals_state (void);
  28. #endif /* COMMON_SIGNALS_STATE_SAVE_RESTORE_H */