|
|
|
#ifndef _ASMARM_UCONTEXT_H
|
|
|
|
#define _ASMARM_UCONTEXT_H
|
|
|
|
|
|
|
|
#include <asm/fpstate.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
* struct sigcontext only has room for the basic registers, but struct
|
|
|
|
* ucontext now has room for all registers which need to be saved and
|
|
|
|
* restored. Coprocessor registers are stored in uc_regspace. Each
|
|
|
|
* coprocessor's saved state should start with a documented 32-bit magic
|
|
|
|
* number, followed by a 32-bit word giving the coproccesor's saved size.
|
|
|
|
* uc_regspace may be expanded if necessary, although this takes some
|
|
|
|
* coordination with glibc.
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct ucontext {
|
|
|
|
unsigned long uc_flags;
|
|
|
|
struct ucontext *uc_link;
|
|
|
|
stack_t uc_stack;
|
|
|
|
struct sigcontext uc_mcontext;
|
|
|
|
sigset_t uc_sigmask;
|
|
|
|
/* Allow for uc_sigmask growth. Glibc uses a 1024-bit sigset_t. */
|
|
|
|
int __unused[32 - (sizeof (sigset_t) / sizeof (int))];
|
|
|
|
/* Last for extensibility. Eight byte aligned because some
|
|
|
|
coprocessors require eight byte alignment. */
|
|
|
|
unsigned long uc_regspace[128] __attribute__((__aligned__(8)));
|
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Coprocessor save state. The magic values and specific
|
|
|
|
* coprocessor's layouts are part of the userspace ABI. Each one of
|
|
|
|
* these should be a multiple of eight bytes and aligned to eight
|
|
|
|
* bytes, to prevent unpredictable padding in the signal frame.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef CONFIG_CRUNCH
|
|
|
|
#define CRUNCH_MAGIC 0x5065cf03
|
|
|
|
#define CRUNCH_STORAGE_SIZE (CRUNCH_SIZE + 8)
|
|
|
|
|
|
|
|
struct crunch_sigframe {
|
|
|
|
unsigned long magic;
|
|
|
|
unsigned long size;
|
|
|
|
struct crunch_state storage;
|
|
|
|
} __attribute__((__aligned__(8)));
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_IWMMXT
|
|
|
|
/* iwmmxt_area is 0x98 bytes long, preceeded by 8 bytes of signature */
|
|
|
|
#define IWMMXT_MAGIC 0x12ef842a
|
|
|
|
#define IWMMXT_STORAGE_SIZE (IWMMXT_SIZE + 8)
|
|
|
|
|
|
|
|
struct iwmmxt_sigframe {
|
|
|
|
unsigned long magic;
|
|
|
|
unsigned long size;
|
|
|
|
struct iwmmxt_struct storage;
|
|
|
|
} __attribute__((__aligned__(8)));
|
|
|
|
#endif /* CONFIG_IWMMXT */
|
|
|
|
|
|
|
|
#ifdef CONFIG_VFP
|
|
|
|
#if __LINUX_ARM_ARCH__ < 6
|
|
|
|
/* For ARM pre-v6, we use fstmiax and fldmiax. This adds one extra
|
|
|
|
* word after the registers, and a word of padding at the end for
|
|
|
|
* alignment. */
|
|
|
|
#define VFP_MAGIC 0x56465001
|
|
|
|
#define VFP_STORAGE_SIZE 152
|
|
|
|
#else
|
|
|
|
#define VFP_MAGIC 0x56465002
|
|
|
|
#define VFP_STORAGE_SIZE 144
|
|
|
|
#endif
|
|
|
|
|
|
|
|
struct vfp_sigframe
|
|
|
|
{
|
|
|
|
unsigned long magic;
|
|
|
|
unsigned long size;
|
|
|
|
union vfp_state storage;
|
|
|
|
};
|
|
|
|
#endif /* CONFIG_VFP */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Auxiliary signal frame. This saves stuff like FP state.
|
|
|
|
* The layout of this structure is not part of the user ABI,
|
|
|
|
* because the config options aren't. uc_regspace is really
|
|
|
|
* one of these.
|
|
|
|
*/
|
|
|
|
struct aux_sigframe {
|
|
|
|
#ifdef CONFIG_CRUNCH
|
|
|
|
struct crunch_sigframe crunch;
|
|
|
|
#endif
|
|
|
|
#ifdef CONFIG_IWMMXT
|
|
|
|
struct iwmmxt_sigframe iwmmxt;
|
|
|
|
#endif
|
|
|
|
#if 0 && defined CONFIG_VFP /* Not yet saved. */
|
|
|
|
struct vfp_sigframe vfp;
|
|
|
|
#endif
|
|
|
|
/* Something that isn't a valid magic number for any coprocessor. */
|
|
|
|
unsigned long end_magic;
|
|
|
|
} __attribute__((__aligned__(8)));
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* !_ASMARM_UCONTEXT_H */
|