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