sparc: unify sigcontext.h
With the renamed types in place the unification was straightforward. Signed-off-by: Sam Ravnborg <sam@ravnborg.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
					parent
					
						
							
								4d7b92ad57
							
						
					
				
			
			
				commit
				
					
						bd703d88a2
					
				
			
		
					 4 changed files with 95 additions and 155 deletions
				
			
		| 
						 | 
				
			
			@ -5,8 +5,6 @@ header-y += ipcbuf_32.h
 | 
			
		|||
header-y += ipcbuf_64.h
 | 
			
		||||
header-y += ptrace_32.h
 | 
			
		||||
header-y += ptrace_64.h
 | 
			
		||||
header-y += sigcontext_32.h
 | 
			
		||||
header-y += sigcontext_64.h
 | 
			
		||||
header-y += siginfo_32.h
 | 
			
		||||
header-y += siginfo_64.h
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,8 +1,96 @@
 | 
			
		|||
#ifndef ___ASM_SPARC_SIGCONTEXT_H
 | 
			
		||||
#define ___ASM_SPARC_SIGCONTEXT_H
 | 
			
		||||
#if defined(__sparc__) && defined(__arch64__)
 | 
			
		||||
#include <asm/sigcontext_64.h>
 | 
			
		||||
#ifndef __SPARC_SIGCONTEXT_H
 | 
			
		||||
#define __SPARC_SIGCONTEXT_H
 | 
			
		||||
 | 
			
		||||
#ifdef __KERNEL__
 | 
			
		||||
#include <asm/ptrace.h>
 | 
			
		||||
 | 
			
		||||
#ifndef __ASSEMBLY__
 | 
			
		||||
 | 
			
		||||
#define __SUNOS_MAXWIN   31
 | 
			
		||||
 | 
			
		||||
/* This is what SunOS does, so shall I unless we use new 32bit signals or rt signals. */
 | 
			
		||||
struct sigcontext32 {
 | 
			
		||||
	int sigc_onstack;      /* state to restore */
 | 
			
		||||
	int sigc_mask;         /* sigmask to restore */
 | 
			
		||||
	int sigc_sp;           /* stack pointer */
 | 
			
		||||
	int sigc_pc;           /* program counter */
 | 
			
		||||
	int sigc_npc;          /* next program counter */
 | 
			
		||||
	int sigc_psr;          /* for condition codes etc */
 | 
			
		||||
	int sigc_g1;           /* User uses these two registers */
 | 
			
		||||
	int sigc_o0;           /* within the trampoline code. */
 | 
			
		||||
 | 
			
		||||
	/* Now comes information regarding the users window set
 | 
			
		||||
	 * at the time of the signal.
 | 
			
		||||
	 */
 | 
			
		||||
	int sigc_oswins;       /* outstanding windows */
 | 
			
		||||
 | 
			
		||||
	/* stack ptrs for each regwin buf */
 | 
			
		||||
	unsigned sigc_spbuf[__SUNOS_MAXWIN];
 | 
			
		||||
 | 
			
		||||
	/* Windows to restore after signal */
 | 
			
		||||
	struct reg_window32 sigc_wbuf[__SUNOS_MAXWIN];
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* This is what we use for 32bit new non-rt signals. */
 | 
			
		||||
 | 
			
		||||
typedef struct {
 | 
			
		||||
	struct {
 | 
			
		||||
		unsigned int psr;
 | 
			
		||||
		unsigned int pc;
 | 
			
		||||
		unsigned int npc;
 | 
			
		||||
		unsigned int y;
 | 
			
		||||
		unsigned int u_regs[16]; /* globals and ins */
 | 
			
		||||
	}			si_regs;
 | 
			
		||||
	int			si_mask;
 | 
			
		||||
} __siginfo32_t;
 | 
			
		||||
 | 
			
		||||
#ifdef CONFIG_SPARC64
 | 
			
		||||
typedef struct {
 | 
			
		||||
	unsigned   int si_float_regs [64];
 | 
			
		||||
	unsigned   long si_fsr;
 | 
			
		||||
	unsigned   long si_gsr;
 | 
			
		||||
	unsigned   long si_fprs;
 | 
			
		||||
} __siginfo_fpu_t;
 | 
			
		||||
 | 
			
		||||
/* This is what SunOS doesn't, so we have to write this alone
 | 
			
		||||
   and do it properly. */
 | 
			
		||||
struct sigcontext {
 | 
			
		||||
	/* The size of this array has to match SI_MAX_SIZE from siginfo.h */
 | 
			
		||||
	char			sigc_info[128];
 | 
			
		||||
	struct {
 | 
			
		||||
		unsigned long	u_regs[16]; /* globals and ins */
 | 
			
		||||
		unsigned long	tstate;
 | 
			
		||||
		unsigned long	tpc;
 | 
			
		||||
		unsigned long	tnpc;
 | 
			
		||||
		unsigned int	y;
 | 
			
		||||
		unsigned int	fprs;
 | 
			
		||||
	}			sigc_regs;
 | 
			
		||||
	__siginfo_fpu_t *	sigc_fpu_save;
 | 
			
		||||
	struct {
 | 
			
		||||
		void	*	ss_sp;
 | 
			
		||||
		int		ss_flags;
 | 
			
		||||
		unsigned long	ss_size;
 | 
			
		||||
	}			sigc_stack;
 | 
			
		||||
	unsigned long		sigc_mask;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#else
 | 
			
		||||
#include <asm/sigcontext_32.h>
 | 
			
		||||
#endif
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
typedef struct {
 | 
			
		||||
	unsigned long si_float_regs [32];
 | 
			
		||||
	unsigned long si_fsr;
 | 
			
		||||
	unsigned long si_fpqdepth;
 | 
			
		||||
	struct {
 | 
			
		||||
		unsigned long *insn_addr;
 | 
			
		||||
		unsigned long insn;
 | 
			
		||||
	} si_fpqueue [16];
 | 
			
		||||
} __siginfo_fpu_t;
 | 
			
		||||
#endif /* (CONFIG_SPARC64) */
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#endif /* !(__ASSEMBLY__) */
 | 
			
		||||
 | 
			
		||||
#endif /* (__KERNEL__) */
 | 
			
		||||
 | 
			
		||||
#endif /* !(__SPARC_SIGCONTEXT_H) */
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,59 +0,0 @@
 | 
			
		|||
#ifndef __SPARC_SIGCONTEXT_H
 | 
			
		||||
#define __SPARC_SIGCONTEXT_H
 | 
			
		||||
 | 
			
		||||
#ifdef __KERNEL__
 | 
			
		||||
#include <asm/ptrace.h>
 | 
			
		||||
 | 
			
		||||
#ifndef __ASSEMBLY__
 | 
			
		||||
 | 
			
		||||
#define __SUNOS_MAXWIN   31
 | 
			
		||||
 | 
			
		||||
/* This is what SunOS does, so shall I. */
 | 
			
		||||
struct sigcontext32 {
 | 
			
		||||
	int sigc_onstack;      /* state to restore */
 | 
			
		||||
	int sigc_mask;         /* sigmask to restore */
 | 
			
		||||
	int sigc_sp;           /* stack pointer */
 | 
			
		||||
	int sigc_pc;           /* program counter */
 | 
			
		||||
	int sigc_npc;          /* next program counter */
 | 
			
		||||
	int sigc_psr;          /* for condition codes etc */
 | 
			
		||||
	int sigc_g1;           /* User uses these two registers */
 | 
			
		||||
	int sigc_o0;           /* within the trampoline code. */
 | 
			
		||||
 | 
			
		||||
	/* Now comes information regarding the users window set
 | 
			
		||||
	 * at the time of the signal.
 | 
			
		||||
	 */
 | 
			
		||||
	int sigc_oswins;       /* outstanding windows */
 | 
			
		||||
 | 
			
		||||
	/* stack ptrs for each regwin buf */
 | 
			
		||||
	char *sigc_spbuf[__SUNOS_MAXWIN];
 | 
			
		||||
 | 
			
		||||
	/* Windows to restore after signal */
 | 
			
		||||
	struct reg_window32 sigc_wbuf[__SUNOS_MAXWIN];
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
typedef struct {
 | 
			
		||||
	struct {
 | 
			
		||||
		unsigned long psr;
 | 
			
		||||
		unsigned long pc;
 | 
			
		||||
		unsigned long npc;
 | 
			
		||||
		unsigned long y;
 | 
			
		||||
		unsigned long u_regs[16]; /* globals and ins */
 | 
			
		||||
	}		si_regs;
 | 
			
		||||
	int		si_mask;
 | 
			
		||||
} __siginfo32_t;
 | 
			
		||||
 | 
			
		||||
typedef struct {
 | 
			
		||||
	unsigned   long si_float_regs [32];
 | 
			
		||||
	unsigned   long si_fsr;
 | 
			
		||||
	unsigned   long si_fpqdepth;
 | 
			
		||||
	struct {
 | 
			
		||||
		unsigned long *insn_addr;
 | 
			
		||||
		unsigned long insn;
 | 
			
		||||
	} si_fpqueue [16];
 | 
			
		||||
} __siginfo_fpu_t;
 | 
			
		||||
 | 
			
		||||
#endif /* !(__ASSEMBLY__) */
 | 
			
		||||
 | 
			
		||||
#endif /* (__KERNEL__) */
 | 
			
		||||
 | 
			
		||||
#endif /* !(__SPARC_SIGCONTEXT_H) */
 | 
			
		||||
| 
						 | 
				
			
			@ -1,87 +0,0 @@
 | 
			
		|||
#ifndef __SPARC64_SIGCONTEXT_H
 | 
			
		||||
#define __SPARC64_SIGCONTEXT_H
 | 
			
		||||
 | 
			
		||||
#ifdef __KERNEL__
 | 
			
		||||
#include <asm/ptrace.h>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifndef __ASSEMBLY__
 | 
			
		||||
 | 
			
		||||
#ifdef __KERNEL__
 | 
			
		||||
 | 
			
		||||
#define __SUNOS_MAXWIN   31
 | 
			
		||||
 | 
			
		||||
/* This is what SunOS does, so shall I unless we use new 32bit signals or rt signals. */
 | 
			
		||||
struct sigcontext32 {
 | 
			
		||||
	int sigc_onstack;      /* state to restore */
 | 
			
		||||
	int sigc_mask;         /* sigmask to restore */
 | 
			
		||||
	int sigc_sp;           /* stack pointer */
 | 
			
		||||
	int sigc_pc;           /* program counter */
 | 
			
		||||
	int sigc_npc;          /* next program counter */
 | 
			
		||||
	int sigc_psr;          /* for condition codes etc */
 | 
			
		||||
	int sigc_g1;           /* User uses these two registers */
 | 
			
		||||
	int sigc_o0;           /* within the trampoline code. */
 | 
			
		||||
 | 
			
		||||
	/* Now comes information regarding the users window set
 | 
			
		||||
	 * at the time of the signal.
 | 
			
		||||
	 */
 | 
			
		||||
	int sigc_oswins;       /* outstanding windows */
 | 
			
		||||
 | 
			
		||||
	/* stack ptrs for each regwin buf */
 | 
			
		||||
	unsigned sigc_spbuf[__SUNOS_MAXWIN];
 | 
			
		||||
 | 
			
		||||
	/* Windows to restore after signal */
 | 
			
		||||
	struct reg_window32 sigc_wbuf[__SUNOS_MAXWIN];
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifdef __KERNEL__
 | 
			
		||||
 | 
			
		||||
/* This is what we use for 32bit new non-rt signals. */
 | 
			
		||||
 | 
			
		||||
typedef struct {
 | 
			
		||||
	struct {
 | 
			
		||||
		unsigned int psr;
 | 
			
		||||
		unsigned int pc;
 | 
			
		||||
		unsigned int npc;
 | 
			
		||||
		unsigned int y;
 | 
			
		||||
		unsigned int u_regs[16]; /* globals and ins */
 | 
			
		||||
	}			si_regs;
 | 
			
		||||
	int			si_mask;
 | 
			
		||||
} __siginfo32_t;
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
typedef struct {
 | 
			
		||||
	unsigned   int si_float_regs [64];
 | 
			
		||||
	unsigned   long si_fsr;
 | 
			
		||||
	unsigned   long si_gsr;
 | 
			
		||||
	unsigned   long si_fprs;
 | 
			
		||||
} __siginfo_fpu_t;
 | 
			
		||||
 | 
			
		||||
/* This is what SunOS doesn't, so we have to write this alone
 | 
			
		||||
   and do it properly. */
 | 
			
		||||
struct sigcontext {
 | 
			
		||||
	/* The size of this array has to match SI_MAX_SIZE from siginfo.h */
 | 
			
		||||
	char			sigc_info[128];
 | 
			
		||||
	struct {
 | 
			
		||||
		unsigned long	u_regs[16]; /* globals and ins */
 | 
			
		||||
		unsigned long	tstate;
 | 
			
		||||
		unsigned long	tpc;
 | 
			
		||||
		unsigned long	tnpc;
 | 
			
		||||
		unsigned int	y;
 | 
			
		||||
		unsigned int	fprs;
 | 
			
		||||
	}			sigc_regs;
 | 
			
		||||
	__siginfo_fpu_t *	sigc_fpu_save;
 | 
			
		||||
	struct {
 | 
			
		||||
		void	*	ss_sp;
 | 
			
		||||
		int		ss_flags;
 | 
			
		||||
		unsigned long	ss_size;
 | 
			
		||||
	}			sigc_stack;
 | 
			
		||||
	unsigned long		sigc_mask;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif /* !(__ASSEMBLY__) */
 | 
			
		||||
 | 
			
		||||
#endif /* !(__SPARC64_SIGCONTEXT_H) */
 | 
			
		||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue