⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 signal.h

📁 this SRC packet is the headfiles that MIZI vivi bootloader needed when compling
💻 H
字号:
/* $Id: signal.h,v 1.35 1999/09/06 08:22:04 jj Exp $ */#ifndef _ASMSPARC_SIGNAL_H#define _ASMSPARC_SIGNAL_H#include <asm/sigcontext.h>#ifdef __KERNEL__#ifndef __ASSEMBLY__#include <linux/personality.h>#include <linux/types.h>#endif#endif/* On the Sparc the signal handlers get passed a 'sub-signal' code * for certain signal types, which we document here. */#define SIGHUP		 1#define SIGINT		 2#define SIGQUIT		 3#define SIGILL		 4#define    SUBSIG_STACK       0#define    SUBSIG_ILLINST     2#define    SUBSIG_PRIVINST    3#define    SUBSIG_BADTRAP(t)  (0x80 + (t))#define SIGTRAP		 5#define SIGABRT		 6#define SIGIOT		 6#define SIGEMT           7#define    SUBSIG_TAG    10#define SIGFPE		 8#define    SUBSIG_FPDISABLED     0x400#define    SUBSIG_FPERROR        0x404#define    SUBSIG_FPINTOVFL      0x001#define    SUBSIG_FPSTSIG        0x002#define    SUBSIG_IDIVZERO       0x014#define    SUBSIG_FPINEXACT      0x0c4#define    SUBSIG_FPDIVZERO      0x0c8#define    SUBSIG_FPUNFLOW       0x0cc#define    SUBSIG_FPOPERROR      0x0d0#define    SUBSIG_FPOVFLOW       0x0d4#define SIGKILL		 9#define SIGBUS          10#define    SUBSIG_BUSTIMEOUT    1#define    SUBSIG_ALIGNMENT     2#define    SUBSIG_MISCERROR     5#define SIGSEGV		11#define    SUBSIG_NOMAPPING     3#define    SUBSIG_PROTECTION    4#define    SUBSIG_SEGERROR      5#define SIGSYS		12#define SIGPIPE		13#define SIGALRM		14#define SIGTERM		15#define SIGURG          16/* SunOS values which deviate from the Linux/i386 ones */#define SIGSTOP		17#define SIGTSTP		18#define SIGCONT		19#define SIGCHLD		20#define SIGTTIN		21#define SIGTTOU		22#define SIGIO		23#define SIGPOLL		SIGIO   /* SysV name for SIGIO */#define SIGXCPU		24#define SIGXFSZ		25#define SIGVTALRM	26#define SIGPROF		27#define SIGWINCH	28#define SIGLOST		29#define SIGPWR		SIGLOST#define SIGUSR1		30#define SIGUSR2		31/* Most things should be clean enough to redefine this at will, if care * is taken to make libc match. */#define __OLD_NSIG	32#define __NEW_NSIG	64#define _NSIG_BPW	32#define _NSIG_WORDS	(__NEW_NSIG / _NSIG_BPW)#define SIGRTMIN	32#define SIGRTMAX	(__NEW_NSIG - 1)#if defined(__KERNEL__) || defined(__WANT_POSIX1B_SIGNALS__)#define	_NSIG		__NEW_NSIG#define __new_sigset_t	sigset_t#define __new_sigaction	sigaction#define __old_sigset_t	old_sigset_t#define __old_sigaction	old_sigaction#else#define _NSIG		__OLD_NSIG#define __old_sigset_t	sigset_t#define __old_sigaction	sigaction#endif#ifndef __ASSEMBLY__typedef unsigned long __old_sigset_t;typedef struct {	unsigned long	sig[_NSIG_WORDS];} __new_sigset_t;/* A SunOS sigstack */struct sigstack {	char *the_stack;	int   cur_status;};/* Sigvec flags */#define SV_SSTACK    1     /* This signal handler should use sig-stack */#define SV_INTR      2     /* Sig return should not restart system call */#define SV_RESET     4     /* Set handler to SIG_DFL upon taken signal */#define SV_IGNCHILD  8     /* Do not send SIGCHLD *//* * sa_flags values: SA_STACK is not currently supported, but will allow the * usage of signal stacks by using the (now obsolete) sa_restorer field in * the sigaction structure as a stack pointer. This is now possible due to * the changes in signal handling. LBT 010493. * SA_INTERRUPT is a no-op, but left due to historical reasons. Use the * SA_RESTART flag to get restarting signals (which were the default long ago) * SA_SHIRQ flag is for shared interrupt support on PCI and EISA. */#define SA_NOCLDSTOP	SV_IGNCHILD#define SA_STACK	SV_SSTACK#define SA_ONSTACK	SV_SSTACK#define SA_RESTART	SV_INTR#define SA_ONESHOT	SV_RESET#define SA_INTERRUPT	0x10#define SA_NOMASK	0x20#define SA_SHIRQ	0x40#define SA_NOCLDWAIT	0x100	/* not supported yet */#define SA_SIGINFO	0x200#define SIG_BLOCK          0x01	/* for blocking signals */#define SIG_UNBLOCK        0x02	/* for unblocking signals */#define SIG_SETMASK        0x04	/* for setting the signal mask *//*  * sigaltstack controls */#define SS_ONSTACK	1#define SS_DISABLE	2#define MINSIGSTKSZ	4096#define SIGSTKSZ	16384#ifdef __KERNEL__/* * These values of sa_flags are used only by the kernel as part of the * irq handling routines. * * SA_INTERRUPT is also used by the irq handling routines. * * DJHR * SA_STATIC_ALLOC is used for the SPARC system to indicate that this * interrupt handler's irq structure should be statically allocated * by the request_irq routine. * The alternative is that arch/sparc/kernel/irq.c has carnal knowledge * of interrupt usage and that sucks. Also without a flag like this * it may be possible for the free_irq routine to attempt to free * statically allocated data.. which is NOT GOOD. * */#define SA_PROBE SA_ONESHOT#define SA_SAMPLE_RANDOM SA_RESTART#define SA_STATIC_ALLOC		0x80#endif/* Type of a signal handler.  */#ifdef __KERNEL__typedef void (*__sighandler_t)(int, int, struct sigcontext *, char *);#elsetypedef void (*__sighandler_t)(int);#endif#define SIG_DFL	((__sighandler_t)0)	/* default signal handling */#define SIG_IGN	((__sighandler_t)1)	/* ignore signal */#define SIG_ERR	((__sighandler_t)-1)	/* error return from signal */struct __new_sigaction {	__sighandler_t	sa_handler;	unsigned long	sa_flags;	void		(*sa_restorer)(void);	/* Not used by Linux/SPARC */	__new_sigset_t	sa_mask;};#ifdef __KERNEL__struct k_sigaction {	struct __new_sigaction	sa;	void			*ka_restorer;};#endifstruct __old_sigaction {	__sighandler_t	sa_handler;	__old_sigset_t	sa_mask;	unsigned long	sa_flags;	void		(*sa_restorer) (void);	/* not used by Linux/SPARC */};typedef struct sigaltstack {	void		*ss_sp;	int		ss_flags;	size_t		ss_size;} stack_t;#endif /* !(__ASSEMBLY__) */#endif /* !(_ASMSPARC_SIGNAL_H) */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -