2005-01-05 22:34:37 +00:00
|
|
|
/*-
|
1999-01-30 06:29:48 +00:00
|
|
|
* Copyright (c) 1998 Mark Newton
|
|
|
|
* Copyright (c) 1994 Christos Zoulas
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. The name of the author may not be used to endorse or promote products
|
|
|
|
* derived from this software without specific prior written permission
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
1999-07-30 12:45:21 +00:00
|
|
|
*
|
1999-08-28 01:08:13 +00:00
|
|
|
* $FreeBSD$
|
1999-01-30 06:29:48 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SVR4_SIGNAL_H_
|
|
|
|
#define _SVR4_SIGNAL_H_
|
|
|
|
|
|
|
|
#include <i386/svr4/svr4_machdep.h>
|
2000-08-31 22:54:09 +00:00
|
|
|
#include <compat/svr4/svr4_siginfo.h>
|
1999-01-30 06:29:48 +00:00
|
|
|
|
|
|
|
#define SVR4_SIGHUP 1
|
|
|
|
#define SVR4_SIGINT 2
|
|
|
|
#define SVR4_SIGQUIT 3
|
|
|
|
#define SVR4_SIGILL 4
|
|
|
|
#define SVR4_SIGTRAP 5
|
|
|
|
#define SVR4_SIGIOT 6
|
|
|
|
#define SVR4_SIGABRT 6
|
|
|
|
#define SVR4_SIGEMT 7
|
|
|
|
#define SVR4_SIGFPE 8
|
|
|
|
#define SVR4_SIGKILL 9
|
|
|
|
#define SVR4_SIGBUS 10
|
|
|
|
#define SVR4_SIGSEGV 11
|
|
|
|
#define SVR4_SIGSYS 12
|
|
|
|
#define SVR4_SIGPIPE 13
|
|
|
|
#define SVR4_SIGALRM 14
|
|
|
|
#define SVR4_SIGTERM 15
|
|
|
|
#define SVR4_SIGUSR1 16
|
|
|
|
#define SVR4_SIGUSR2 17
|
|
|
|
#define SVR4_SIGCLD 18
|
|
|
|
#define SVR4_SIGCHLD 18
|
|
|
|
#define SVR4_SIGPWR 19
|
|
|
|
#define SVR4_SIGWINCH 20
|
|
|
|
#define SVR4_SIGURG 21
|
|
|
|
#define SVR4_SIGPOLL 22
|
|
|
|
#define SVR4_SIGIO 22
|
|
|
|
#define SVR4_SIGSTOP 23
|
|
|
|
#define SVR4_SIGTSTP 24
|
|
|
|
#define SVR4_SIGCONT 25
|
|
|
|
#define SVR4_SIGTTIN 26
|
|
|
|
#define SVR4_SIGTTOU 27
|
|
|
|
#define SVR4_SIGVTALRM 28
|
|
|
|
#define SVR4_SIGPROF 29
|
|
|
|
#define SVR4_SIGXCPU 30
|
|
|
|
#define SVR4_SIGXFSZ 31
|
2000-01-15 15:38:17 +00:00
|
|
|
#define SVR4_NSIG 32
|
1999-01-30 06:29:48 +00:00
|
|
|
|
|
|
|
#define SVR4_SIGNO_MASK 0x00FF
|
|
|
|
#define SVR4_SIGNAL_MASK 0x0000
|
|
|
|
#define SVR4_SIGDEFER_MASK 0x0100
|
|
|
|
#define SVR4_SIGHOLD_MASK 0x0200
|
|
|
|
#define SVR4_SIGRELSE_MASK 0x0400
|
|
|
|
#define SVR4_SIGIGNORE_MASK 0x0800
|
|
|
|
#define SVR4_SIGPAUSE_MASK 0x1000
|
|
|
|
|
2002-03-20 05:48:58 +00:00
|
|
|
typedef void (*svr4_sig_t)(int, svr4_siginfo_t *, void *);
|
1999-01-30 06:29:48 +00:00
|
|
|
#define SVR4_SIG_DFL (svr4_sig_t) 0
|
|
|
|
#define SVR4_SIG_ERR (svr4_sig_t) -1
|
|
|
|
#define SVR4_SIG_IGN (svr4_sig_t) 1
|
|
|
|
#define SVR4_SIG_HOLD (svr4_sig_t) 2
|
|
|
|
|
|
|
|
#define SVR4_SIGNO(a) ((a) & SVR4_SIGNO_MASK)
|
|
|
|
#define SVR4_SIGCALL(a) ((a) & ~SVR4_SIGNO_MASK)
|
|
|
|
|
|
|
|
#define SVR4_SIG_BLOCK 1
|
|
|
|
#define SVR4_SIG_UNBLOCK 2
|
|
|
|
#define SVR4_SIG_SETMASK 3
|
|
|
|
|
2005-02-25 19:34:10 +00:00
|
|
|
extern int bsd_to_svr4_sig[SVR4_NSIG];
|
|
|
|
extern int svr4_to_bsd_sig[SVR4_NSIG];
|
1999-09-29 15:12:18 +00:00
|
|
|
|
|
|
|
#define SVR4_BSD2SVR4_SIG(sig) \
|
2005-02-25 19:34:10 +00:00
|
|
|
(((sig) < SVR4_NSIG) ? bsd_to_svr4_sig[sig] : sig)
|
1999-09-29 15:12:18 +00:00
|
|
|
#define SVR4_SVR42BSD_SIG(sig) \
|
2005-02-25 19:34:10 +00:00
|
|
|
(((sig) < SVR4_NSIG) ? svr4_to_bsd_sig[sig] : sig)
|
1999-09-29 15:12:18 +00:00
|
|
|
|
1999-01-30 06:29:48 +00:00
|
|
|
typedef struct {
|
|
|
|
u_long bits[4];
|
|
|
|
} svr4_sigset_t;
|
|
|
|
|
|
|
|
struct svr4_sigaction {
|
1999-07-06 06:55:29 +00:00
|
|
|
int ssa_flags;
|
|
|
|
svr4_sig_t ssa_handler;
|
|
|
|
svr4_sigset_t ssa_mask;
|
|
|
|
int ssa_reserved[2];
|
1999-01-30 06:29:48 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct svr4_sigaltstack {
|
|
|
|
char *ss_sp;
|
|
|
|
int ss_size;
|
|
|
|
int ss_flags;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* sa_flags */
|
|
|
|
#define SVR4_SA_ONSTACK 0x00000001
|
|
|
|
#define SVR4_SA_RESETHAND 0x00000002
|
|
|
|
#define SVR4_SA_RESTART 0x00000004
|
|
|
|
#define SVR4_SA_SIGINFO 0x00000008
|
|
|
|
#define SVR4_SA_NODEFER 0x00000010
|
|
|
|
#define SVR4_SA_NOCLDWAIT 0x00010000 /* No zombies */
|
|
|
|
#define SVR4_SA_NOCLDSTOP 0x00020000 /* No jcl */
|
|
|
|
#define SVR4_SA_ALLBITS 0x0003001f
|
|
|
|
|
|
|
|
/* ss_flags */
|
|
|
|
#define SVR4_SS_ONSTACK 0x00000001
|
|
|
|
#define SVR4_SS_DISABLE 0x00000002
|
|
|
|
#define SVR4_SS_ALLBITS 0x00000003
|
|
|
|
|
2000-11-09 08:25:48 +00:00
|
|
|
#define SVR4_MINSIGSTKSZ 8192
|
|
|
|
|
1. Change prototype of trapsignal and sendsig to use ksiginfo_t *, most
changes in MD code are trivial, before this change, trapsignal and
sendsig use discrete parameters, now they uses member fields of
ksiginfo_t structure. For sendsig, this change allows us to pass
POSIX realtime signal value to user code.
2. Remove cpu_thread_siginfo, it is no longer needed because we now always
generate ksiginfo_t data and feed it to libpthread.
3. Add p_sigqueue to proc structure to hold shared signals which were
blocked by all threads in the proc.
4. Add td_sigqueue to thread structure to hold all signals delivered to
thread.
5. i386 and amd64 now return POSIX standard si_code, other arches will
be fixed.
6. In this sigqueue implementation, pending signal set is kept as before,
an extra siginfo list holds additional siginfo_t data for signals.
kernel code uses psignal() still behavior as before, it won't be failed
even under memory pressure, only exception is when deleting a signal,
we should call sigqueue_delete to remove signal from sigqueue but
not SIGDELSET. Current there is no kernel code will deliver a signal
with additional data, so kernel should be as stable as before,
a ksiginfo can carry more information, for example, allow signal to
be delivered but throw away siginfo data if memory is not enough.
SIGKILL and SIGSTOP have fast path in sigqueue_add, because they can
not be caught or masked.
The sigqueue() syscall allows user code to queue a signal to target
process, if resource is unavailable, EAGAIN will be returned as
specification said.
Just before thread exits, signal queue memory will be freed by
sigqueue_flush.
Current, all signals are allowed to be queued, not only realtime signals.
Earlier patch reviewed by: jhb, deischen
Tested on: i386, amd64
2005-10-14 12:43:47 +00:00
|
|
|
struct ksiginfo;
|
|
|
|
|
2002-03-20 05:48:58 +00:00
|
|
|
void bsd_to_svr4_sigaltstack(const struct sigaltstack *, struct svr4_sigaltstack *);
|
|
|
|
void bsd_to_svr4_sigset(const sigset_t *, svr4_sigset_t *);
|
|
|
|
void svr4_to_bsd_sigaltstack(const struct svr4_sigaltstack *, struct sigaltstack *);
|
|
|
|
void svr4_to_bsd_sigset(const svr4_sigset_t *, sigset_t *);
|
1. Change prototype of trapsignal and sendsig to use ksiginfo_t *, most
changes in MD code are trivial, before this change, trapsignal and
sendsig use discrete parameters, now they uses member fields of
ksiginfo_t structure. For sendsig, this change allows us to pass
POSIX realtime signal value to user code.
2. Remove cpu_thread_siginfo, it is no longer needed because we now always
generate ksiginfo_t data and feed it to libpthread.
3. Add p_sigqueue to proc structure to hold shared signals which were
blocked by all threads in the proc.
4. Add td_sigqueue to thread structure to hold all signals delivered to
thread.
5. i386 and amd64 now return POSIX standard si_code, other arches will
be fixed.
6. In this sigqueue implementation, pending signal set is kept as before,
an extra siginfo list holds additional siginfo_t data for signals.
kernel code uses psignal() still behavior as before, it won't be failed
even under memory pressure, only exception is when deleting a signal,
we should call sigqueue_delete to remove signal from sigqueue but
not SIGDELSET. Current there is no kernel code will deliver a signal
with additional data, so kernel should be as stable as before,
a ksiginfo can carry more information, for example, allow signal to
be delivered but throw away siginfo data if memory is not enough.
SIGKILL and SIGSTOP have fast path in sigqueue_add, because they can
not be caught or masked.
The sigqueue() syscall allows user code to queue a signal to target
process, if resource is unavailable, EAGAIN will be returned as
specification said.
Just before thread exits, signal queue memory will be freed by
sigqueue_flush.
Current, all signals are allowed to be queued, not only realtime signals.
Earlier patch reviewed by: jhb, deischen
Tested on: i386, amd64
2005-10-14 12:43:47 +00:00
|
|
|
void svr4_sendsig(sig_t, struct ksiginfo *, sigset_t *);
|
1999-01-30 06:29:48 +00:00
|
|
|
|
|
|
|
#endif /* !_SVR4_SIGNAL_H_ */
|