1 /* Copyright (C) 1998, 1999, 2002, 2003, 2004 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
4 The GNU C Library is free software; you can redistribute it and/or
5 modify it under the terms of the GNU Lesser General Public
6 License as published by the Free Software Foundation; either
7 version 2.1 of the License, or (at your option) any later version.
9 The GNU C Library is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 Lesser General Public License for more details.
14 You should have received a copy of the GNU Lesser General Public
15 License along with the GNU C Library; if not, write to the Free
16 Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
19 /* System V/mips ABI compliant context switching support. */
21 #ifndef _SYS_UCONTEXT_H
22 #define _SYS_UCONTEXT_H 1
28 /* Type for general register. */
29 #if _MIPS_SIM == _ABIO32
30 typedef __uint32_t greg_t
;
32 typedef __uint64_t greg_t
;
35 /* Number of general registers. */
38 /* Container for all general registers. */
39 typedef greg_t gregset_t
[NGREG
];
41 /* Number of each register is the `gregset_t' array. */
101 #define CTX_GP CTX_GP
103 #define CTX_SP CTX_SP
105 #define CTX_S8 CTX_S8
107 #define CTX_RA CTX_RA
109 #define CTX_MDLO CTX_MDLO
111 #define CTX_MDHI CTX_MDHI
113 #define CTX_CAUSE CTX_CAUSE
115 #define CTX_EPC CTX_EPC
118 /* Structure to describe FPU registers. */
119 typedef struct fpregset
123 #if _MIPS_SIM == _ABIO32
126 unsigned int fp_regs
[32];
129 /* float fp_fregs[32]; */
130 __uint64_t fp_regs
[32];
137 /* Context to describe whole processor state. */
144 /* Userlevel context. */
145 typedef struct ucontext
147 #if _MIPS_SIM == _ABIO32
148 unsigned long int uc_flags
;
152 struct ucontext
*uc_link
;
153 __sigset_t uc_sigmask
;
155 mcontext_t uc_mcontext
;
159 #endif /* sys/ucontext.h */