[ARM] move include/asm-arm to arch/arm/include/asm
Move platform independent header files to arch/arm/include/asm, leaving those in asm/arch* and asm/plat* alone. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:

committed by
Russell King

parent
ff4db0a043
commit
4baa992243
103
arch/arm/include/asm/ucontext.h
Normal file
103
arch/arm/include/asm/ucontext.h
Normal file
@@ -0,0 +1,103 @@
|
||||
#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 */
|
Reference in New Issue
Block a user