1#ifndef _ASMARM_UCONTEXT_H 2#define _ASMARM_UCONTEXT_H 3 4#include <asm/fpstate.h> 5 6/* 7 * struct sigcontext only has room for the basic registers, but struct 8 * ucontext now has room for all registers which need to be saved and 9 * restored. Coprocessor registers are stored in uc_regspace. Each 10 * coprocessor's saved state should start with a documented 32-bit magic 11 * number, followed by a 32-bit word giving the coproccesor's saved size. 12 * uc_regspace may be expanded if necessary, although this takes some 13 * coordination with glibc. 14 */ 15 16struct ucontext { 17 unsigned long uc_flags; 18 struct ucontext *uc_link; 19 stack_t uc_stack; 20 struct sigcontext uc_mcontext; 21 sigset_t uc_sigmask; 22 /* Allow for uc_sigmask growth. Glibc uses a 1024-bit sigset_t. */ 23 int __unused[32 - (sizeof (sigset_t) / sizeof (int))]; 24 /* Last for extensibility. Eight byte aligned because some 25 coprocessors require eight byte alignment. */ 26 unsigned long uc_regspace[128] __attribute__((__aligned__(8))); 27}; 28 29#ifdef __KERNEL__ 30 31/* 32 * Coprocessor save state. The magic values and specific 33 * coprocessor's layouts are part of the userspace ABI. Each one of 34 * these should be a multiple of eight bytes and aligned to eight 35 * bytes, to prevent unpredictable padding in the signal frame. 36 */ 37 38#ifdef CONFIG_CRUNCH 39#define CRUNCH_MAGIC 0x5065cf03 40#define CRUNCH_STORAGE_SIZE (CRUNCH_SIZE + 8) 41 42struct crunch_sigframe { 43 unsigned long magic; 44 unsigned long size; 45 struct crunch_state storage; 46} __attribute__((__aligned__(8))); 47#endif 48 49#ifdef CONFIG_IWMMXT 50/* iwmmxt_area is 0x98 bytes long, preceeded by 8 bytes of signature */ 51#define IWMMXT_MAGIC 0x12ef842a 52#define IWMMXT_STORAGE_SIZE (IWMMXT_SIZE + 8) 53 54struct iwmmxt_sigframe { 55 unsigned long magic; 56 unsigned long size; 57 struct iwmmxt_struct storage; 58} __attribute__((__aligned__(8))); 59#endif /* CONFIG_IWMMXT */ 60 61#ifdef CONFIG_VFP 62#if __LINUX_ARM_ARCH__ < 6 63/* For ARM pre-v6, we use fstmiax and fldmiax. This adds one extra 64 * word after the registers, and a word of padding at the end for 65 * alignment. */ 66#define VFP_MAGIC 0x56465001 67#define VFP_STORAGE_SIZE 152 68#else 69#define VFP_MAGIC 0x56465002 70#define VFP_STORAGE_SIZE 144 71#endif 72 73struct vfp_sigframe 74{ 75 unsigned long magic; 76 unsigned long size; 77 union vfp_state storage; 78}; 79#endif /* CONFIG_VFP */ 80 81/* 82 * Auxiliary signal frame. This saves stuff like FP state. 83 * The layout of this structure is not part of the user ABI, 84 * because the config options aren't. uc_regspace is really 85 * one of these. 86 */ 87struct aux_sigframe { 88#ifdef CONFIG_CRUNCH 89 struct crunch_sigframe crunch; 90#endif 91#ifdef CONFIG_IWMMXT 92 struct iwmmxt_sigframe iwmmxt; 93#endif 94#if 0 && defined CONFIG_VFP /* Not yet saved. */ 95 struct vfp_sigframe vfp; 96#endif 97 /* Something that isn't a valid magic number for any coprocessor. */ 98 unsigned long end_magic; 99} __attribute__((__aligned__(8))); 100 101#endif 102 103#endif /* !_ASMARM_UCONTEXT_H */ 104