1 /* Copyright (C) 1998-2014 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, see
16 <http://www.gnu.org/licenses/>. */
18 /* System V/mips ABI compliant context switching support. */
20 #ifndef _SYS_UCONTEXT_H
21 #define _SYS_UCONTEXT_H 1
27 /* Type for general register. */
28 #if _MIPS_SIM == _ABIO32
29 typedef __uint32_t greg_t
;
31 typedef __uint64_t greg_t
;
34 /* Number of general registers. */
37 /* Container for all general registers. */
38 typedef greg_t gregset_t
[NGREG
];
40 /* Number of each register is the `gregset_t' array. */
100 #define CTX_GP CTX_GP
102 #define CTX_SP CTX_SP
104 #define CTX_S8 CTX_S8
106 #define CTX_RA CTX_RA
108 #define CTX_MDLO CTX_MDLO
110 #define CTX_MDHI CTX_MDHI
112 #define CTX_CAUSE CTX_CAUSE
114 #define CTX_EPC CTX_EPC
117 /* Structure to describe FPU registers. */
118 typedef struct fpregset
122 #if _MIPS_SIM == _ABIO32
125 unsigned int fp_regs
[32];
128 /* float fp_fregs[32]; */
129 __uint64_t fp_regs
[32];
136 /* Context to describe whole processor state. */
143 /* Userlevel context. */
144 typedef struct ucontext
146 #if _MIPS_SIM == _ABIO32
147 unsigned long int uc_flags
;
151 struct ucontext
*uc_link
;
152 __sigset_t uc_sigmask
;
154 mcontext_t uc_mcontext
;
158 #endif /* sys/ucontext.h */