home *** CD-ROM | disk | FTP | other *** search
/ Mac Easy 2010 May / Mac Life Ubuntu.iso / casper / filesystem.squashfs / usr / src / linux-headers-2.6.28-15 / arch / arm / include / asm / ucontext.h < prev    next >
Encoding:
C/C++ Source or Header  |  2008-12-24  |  2.9 KB  |  104 lines

  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.  
  16. struct 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.  
  42. struct 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.  
  54. struct 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.  
  73. struct 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.  */
  87. struct 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.