blob: 99ccca415d123f154b5f8fed788e49f2784d62de [file] [log] [blame]
njn0c246472005-05-31 01:00:08 +00001
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-2005 Julian Seward
11 jseward@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
njn73c51342005-06-18 15:18:15 +000038#include "pub_tool_signals.h" // I want to get rid of this header...
39
njn0c246472005-05-31 01:00:08 +000040/* Highest signal the kernel will let us use */
41extern Int VG_(max_signal);
42
43extern void VG_(sigstartup_actions) ( void );
44
sewardja8d8e232005-06-07 20:04:56 +000045/* Poll a thread's set of pending signals, and update the Thread's
46 context to deliver one (viz, create signal frames if needed) */
njn0c246472005-05-31 01:00:08 +000047extern void VG_(poll_signals) ( ThreadId );
48
49/* Fake system calls for signal handling. */
sewardja8d8e232005-06-07 20:04:56 +000050extern SysRes VG_(do_sys_sigaltstack) ( ThreadId tid, vki_stack_t* ss,
51 vki_stack_t* oss );
52extern SysRes VG_(do_sys_sigaction) ( Int signo,
53 const struct vki_sigaction *new_act,
54 struct vki_sigaction *old_act );
55extern SysRes VG_(do_sys_sigprocmask) ( ThreadId tid, Int how,
56 vki_sigset_t* set,
57 vki_sigset_t* oldset );
njn0c246472005-05-31 01:00:08 +000058
59extern void VG_(clear_out_queued_signals)
60 ( ThreadId tid, /* OUT */ vki_sigset_t* saved_mask );
61
62extern void VG_(kill_self)(Int sigNo);
63
64/* These function synthesize a fault, as if the running instruction
65 had had a fault. These functions do not return - they longjmp back
66 into the scheduler so the signal can be delivered. */
67extern void VG_(synth_fault) (ThreadId tid);
68extern void VG_(synth_fault_mapping)(ThreadId tid, Addr addr);
69extern void VG_(synth_fault_perms) (ThreadId tid, Addr addr);
70extern void VG_(synth_sigill) (ThreadId tid, Addr addr);
71
72/* Extend the stack to cover addr, if possible */
73extern Bool VG_(extend_stack)(Addr addr, UInt maxsize);
74
75/* Returns True if the signal is OK for the client to use */
76extern Bool VG_(client_signal_OK)(Int sigNo);
77
78/* Forces the client's signal handler to SIG_DFL - generally just
79 before using that signal to kill the process. */
80extern void VG_(set_default_handler)(Int sig);
81
82#endif // __PUB_CORE_SIGNALS_H
83
84/*--------------------------------------------------------------------*/
85/*--- end ---*/
86/*--------------------------------------------------------------------*/