mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 8070361799
			
		
	
	
		8070361799
		
	
	
	
	
		
			
			The vector extension introduces 32 128-bit vector registers and a set of instruction to operate on the vector registers. The kernel can control the use of vector registers for the problem state program with a bit in control register 0. Once enabled for a process the kernel needs to retain the content of the vector registers on context switch. The signal frame is extended to include the vector registers. Two new register sets NT_S390_VXRS_LOW and NT_S390_VXRS_HIGH are added to the regset interface for the debugger and core dumps. Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
		
			
				
	
	
		
			85 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *  S390 version
 | |
|  *    Copyright IBM Corp. 1999, 2000
 | |
|  */
 | |
| 
 | |
| #ifndef _ASM_S390_SIGCONTEXT_H
 | |
| #define _ASM_S390_SIGCONTEXT_H
 | |
| 
 | |
| #include <linux/compiler.h>
 | |
| #include <linux/types.h>
 | |
| 
 | |
| #define __NUM_GPRS		16
 | |
| #define __NUM_FPRS		16
 | |
| #define __NUM_ACRS		16
 | |
| #define __NUM_VXRS		32
 | |
| #define __NUM_VXRS_LOW		16
 | |
| #define __NUM_VXRS_HIGH		16
 | |
| 
 | |
| #ifndef __s390x__
 | |
| 
 | |
| /* Has to be at least _NSIG_WORDS from asm/signal.h */
 | |
| #define _SIGCONTEXT_NSIG	64
 | |
| #define _SIGCONTEXT_NSIG_BPW	32
 | |
| /* Size of stack frame allocated when calling signal handler. */
 | |
| #define __SIGNAL_FRAMESIZE	96
 | |
| 
 | |
| #else /* __s390x__ */
 | |
| 
 | |
| /* Has to be at least _NSIG_WORDS from asm/signal.h */
 | |
| #define _SIGCONTEXT_NSIG	64
 | |
| #define _SIGCONTEXT_NSIG_BPW	64 
 | |
| /* Size of stack frame allocated when calling signal handler. */
 | |
| #define __SIGNAL_FRAMESIZE	160
 | |
| 
 | |
| #endif /* __s390x__ */
 | |
| 
 | |
| #define _SIGCONTEXT_NSIG_WORDS	(_SIGCONTEXT_NSIG / _SIGCONTEXT_NSIG_BPW)
 | |
| #define _SIGMASK_COPY_SIZE	(sizeof(unsigned long)*_SIGCONTEXT_NSIG_WORDS)
 | |
| 
 | |
| typedef struct 
 | |
| {
 | |
|         unsigned long mask;
 | |
|         unsigned long addr;
 | |
| } __attribute__ ((aligned(8))) _psw_t;
 | |
| 
 | |
| typedef struct
 | |
| {
 | |
| 	_psw_t psw;
 | |
| 	unsigned long gprs[__NUM_GPRS];
 | |
| 	unsigned int  acrs[__NUM_ACRS];
 | |
| } _s390_regs_common;
 | |
| 
 | |
| typedef struct
 | |
| {
 | |
| 	unsigned int fpc;
 | |
| 	unsigned int pad;
 | |
| 	double   fprs[__NUM_FPRS];
 | |
| } _s390_fp_regs;
 | |
| 
 | |
| typedef struct
 | |
| {
 | |
| 	_s390_regs_common regs;
 | |
| 	_s390_fp_regs     fpregs;
 | |
| } _sigregs;
 | |
| 
 | |
| typedef struct
 | |
| {
 | |
| #ifndef __s390x__
 | |
| 	unsigned long gprs_high[__NUM_GPRS];
 | |
| #endif
 | |
| 	unsigned long long vxrs_low[__NUM_VXRS_LOW];
 | |
| 	__vector128 vxrs_high[__NUM_VXRS_HIGH];
 | |
| 	unsigned char __reserved[128];
 | |
| } _sigregs_ext;
 | |
| 
 | |
| struct sigcontext
 | |
| {
 | |
| 	unsigned long	oldmask[_SIGCONTEXT_NSIG_WORDS];
 | |
| 	_sigregs        __user *sregs;
 | |
| };
 | |
| 
 | |
| 
 | |
| #endif
 | |
| 
 |