1 2 /*--------------------------------------------------------------------*/ 3 /*--- POSIX signals. pub_core_signals.h ---*/ 4 /*--------------------------------------------------------------------*/ 5 6 /* 7 This file is part of Valgrind, a dynamic binary instrumentation 8 framework. 9 10 Copyright (C) 2000-2012 Julian Seward 11 jseward (at) acm.org 12 13 This program is free software; you can redistribute it and/or 14 modify it under the terms of the GNU General Public License as 15 published by the Free Software Foundation; either version 2 of the 16 License, or (at your option) any later version. 17 18 This program is distributed in the hope that it will be useful, but 19 WITHOUT ANY WARRANTY; without even the implied warranty of 20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 21 General Public License for more details. 22 23 You should have received a copy of the GNU General Public License 24 along with this program; if not, write to the Free Software 25 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 26 02111-1307, USA. 27 28 The GNU General Public License is contained in the file COPYING. 29 */ 30 31 #ifndef __PUB_CORE_SIGNALS_H 32 #define __PUB_CORE_SIGNALS_H 33 34 //-------------------------------------------------------------------- 35 // PURPOSE: This module implements all the signal handling stuff. 36 //-------------------------------------------------------------------- 37 38 #include "pub_tool_signals.h" // I want to get rid of this header... 39 40 /* Highest signal the kernel will let us use */ 41 extern Int VG_(max_signal); 42 43 /* Returns the name of the vki signal sigNo */ 44 extern const Char *VG_(signame)(Int sigNo); 45 46 /* Use high signals because native pthreads wants to use low */ 47 #define VG_SIGVGKILL (VG_(max_signal)-0) 48 #define VG_SIGVGRTUSERMAX (VG_(max_signal)-1) 49 50 extern void VG_(sigstartup_actions) ( void ); 51 52 /* Poll a thread's set of pending signals, and update the Thread's 53 context to deliver one (viz, create signal frames if needed) */ 54 extern void VG_(poll_signals) ( ThreadId ); 55 56 /* Fake system calls for signal handling. */ 57 extern SysRes VG_(do_sys_sigaltstack) ( ThreadId tid, vki_stack_t* ss, 58 vki_stack_t* oss ); 59 extern SysRes VG_(do_sys_sigaction) ( Int signo, 60 const vki_sigaction_toK_t* new_act, 61 vki_sigaction_fromK_t* old_act ); 62 extern SysRes VG_(do_sys_sigprocmask) ( ThreadId tid, Int how, 63 vki_sigset_t* set, 64 vki_sigset_t* oldset ); 65 66 extern void VG_(clear_out_queued_signals) 67 ( ThreadId tid, /* OUT */ vki_sigset_t* saved_mask ); 68 69 extern void VG_(kill_self)(Int sigNo); 70 71 /* These function synthesize a fault, as if the running instruction 72 had had a fault. These functions do not return - they longjmp back 73 into the scheduler so the signal can be delivered. */ 74 extern void VG_(synth_fault) (ThreadId tid); 75 extern void VG_(synth_fault_mapping)(ThreadId tid, Addr addr); 76 extern void VG_(synth_fault_perms) (ThreadId tid, Addr addr); 77 extern void VG_(synth_sigill) (ThreadId tid, Addr addr); 78 extern void VG_(synth_sigtrap) (ThreadId tid); 79 extern void VG_(synth_sigbus) (ThreadId tid); 80 81 /* Extend the stack to cover addr, if possible */ 82 extern Bool VG_(extend_stack)(Addr addr, UInt maxsize); 83 84 /* Forces the client's signal handler to SIG_DFL - generally just 85 before using that signal to kill the process. */ 86 extern void VG_(set_default_handler)(Int sig); 87 88 #endif // __PUB_CORE_SIGNALS_H 89 90 /*--------------------------------------------------------------------*/ 91 /*--- end ---*/ 92 /*--------------------------------------------------------------------*/ 93