2014-01-27 14:56:43 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 The Android Open Source Project
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* * Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in
|
|
|
|
* the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
|
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
|
|
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
|
|
|
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SYS_UCONTEXT_H_
|
|
|
|
#define _SYS_UCONTEXT_H_
|
|
|
|
|
2016-07-22 23:56:18 +02:00
|
|
|
#include <sys/cdefs.h>
|
2016-11-08 03:27:16 +01:00
|
|
|
|
|
|
|
#include <signal.h>
|
2014-01-27 14:56:43 +01:00
|
|
|
#include <sys/user.h>
|
|
|
|
|
|
|
|
__BEGIN_DECLS
|
|
|
|
|
2014-01-30 01:46:00 +01:00
|
|
|
#if defined(__arm__)
|
|
|
|
|
2014-01-30 02:53:59 +01:00
|
|
|
enum {
|
|
|
|
REG_R0 = 0,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R0 REG_R0
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R1,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R1 REG_R1
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R2,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R2 REG_R2
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R3,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R3 REG_R3
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R4,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R4 REG_R4
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R5,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R5 REG_R5
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R6,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R6 REG_R6
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R7,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R7 REG_R7
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R8,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R8 REG_R8
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R9,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R9 REG_R9
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R10,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R10 REG_R10
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R11,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R11 REG_R11
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R12,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R12 REG_R12
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R13,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R13 REG_R13
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R14,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R14 REG_R14
|
2014-01-30 02:53:59 +01:00
|
|
|
REG_R15,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R15 REG_R15
|
2014-01-30 02:53:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#define NGREG 18 /* Like glibc. */
|
|
|
|
|
|
|
|
typedef int greg_t;
|
|
|
|
typedef greg_t gregset_t[NGREG];
|
2015-03-04 19:31:29 +01:00
|
|
|
typedef struct user_fpregs fpregset_t;
|
2014-01-30 02:53:59 +01:00
|
|
|
|
|
|
|
#include <asm/sigcontext.h>
|
|
|
|
typedef struct sigcontext mcontext_t;
|
|
|
|
|
|
|
|
typedef struct ucontext {
|
|
|
|
unsigned long uc_flags;
|
|
|
|
struct ucontext* uc_link;
|
|
|
|
stack_t uc_stack;
|
|
|
|
mcontext_t uc_mcontext;
|
2014-09-13 05:04:40 +02:00
|
|
|
sigset_t uc_sigmask;
|
2016-06-09 03:11:23 +02:00
|
|
|
/* Android has a wrong (smaller) sigset_t on ARM. */
|
2014-09-13 05:04:40 +02:00
|
|
|
uint32_t __padding_rt_sigset;
|
2016-06-09 03:11:23 +02:00
|
|
|
/* The kernel adds extra padding after uc_sigmask to match glibc sigset_t on ARM. */
|
2014-05-28 16:56:46 +02:00
|
|
|
char __padding[120];
|
2014-05-19 20:14:03 +02:00
|
|
|
unsigned long uc_regspace[128] __attribute__((__aligned__(8)));
|
2014-01-30 02:53:59 +01:00
|
|
|
} ucontext_t;
|
2014-01-30 01:46:00 +01:00
|
|
|
|
2014-01-31 05:45:53 +01:00
|
|
|
#elif defined(__aarch64__)
|
2014-01-30 01:46:00 +01:00
|
|
|
|
2014-09-19 19:31:49 +02:00
|
|
|
#define NGREG 34 /* x0..x30 + sp + pc + pstate */
|
|
|
|
typedef unsigned long greg_t;
|
|
|
|
typedef greg_t gregset_t[NGREG];
|
2015-06-16 03:47:39 +02:00
|
|
|
typedef struct user_fpsimd_struct fpregset_t;
|
2015-03-04 19:31:29 +01:00
|
|
|
|
2014-01-31 05:45:53 +01:00
|
|
|
#include <asm/sigcontext.h>
|
|
|
|
typedef struct sigcontext mcontext_t;
|
|
|
|
|
|
|
|
typedef struct ucontext {
|
|
|
|
unsigned long uc_flags;
|
|
|
|
struct ucontext *uc_link;
|
|
|
|
stack_t uc_stack;
|
|
|
|
sigset_t uc_sigmask;
|
2016-06-09 03:11:23 +02:00
|
|
|
/* The kernel adds extra padding after uc_sigmask to match glibc sigset_t on ARM64. */
|
2014-04-07 23:36:59 +02:00
|
|
|
char __padding[128 - sizeof(sigset_t)];
|
2014-01-31 05:45:53 +01:00
|
|
|
mcontext_t uc_mcontext;
|
|
|
|
} ucontext_t;
|
2014-01-30 01:46:00 +01:00
|
|
|
|
|
|
|
#elif defined(__i386__)
|
|
|
|
|
|
|
|
enum {
|
|
|
|
REG_GS = 0,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_GS REG_GS
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_FS,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_FS REG_FS
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_ES,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_ES REG_ES
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_DS,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_DS REG_DS
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_EDI,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_EDI REG_EDI
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_ESI,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_ESI REG_ESI
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_EBP,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_EBP REG_EBP
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_ESP,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_ESP REG_ESP
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_EBX,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_EBX REG_EBX
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_EDX,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_EDX REG_EDX
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_ECX,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_ECX REG_ECX
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_EAX,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_EAX REG_EAX
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_TRAPNO,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_TRAPNO REG_TRAPNO
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_ERR,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_ERR REG_ERR
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_EIP,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_EIP REG_EIP
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_CS,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_CS REG_CS
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_EFL,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_EFL REG_EFL
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_UESP,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_UESP REG_UESP
|
2014-01-30 01:46:00 +01:00
|
|
|
REG_SS,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_SS REG_SS
|
2014-01-30 01:46:00 +01:00
|
|
|
NGREG
|
2017-06-16 00:12:29 +02:00
|
|
|
#define NGREG NGREG
|
2014-01-30 01:46:00 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef int greg_t;
|
|
|
|
typedef greg_t gregset_t[NGREG];
|
|
|
|
|
|
|
|
struct _libc_fpreg {
|
|
|
|
unsigned short significand[4];
|
|
|
|
unsigned short exponent;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct _libc_fpstate {
|
|
|
|
unsigned long cw;
|
|
|
|
unsigned long sw;
|
|
|
|
unsigned long tag;
|
|
|
|
unsigned long ipoff;
|
|
|
|
unsigned long cssel;
|
|
|
|
unsigned long dataoff;
|
|
|
|
unsigned long datasel;
|
|
|
|
struct _libc_fpreg _st[8];
|
|
|
|
unsigned long status;
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct _libc_fpstate* fpregset_t;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
gregset_t gregs;
|
|
|
|
fpregset_t fpregs;
|
|
|
|
unsigned long oldmask;
|
|
|
|
unsigned long cr2;
|
|
|
|
} mcontext_t;
|
|
|
|
|
|
|
|
typedef struct ucontext {
|
|
|
|
unsigned long uc_flags;
|
|
|
|
struct ucontext* uc_link;
|
|
|
|
stack_t uc_stack;
|
|
|
|
mcontext_t uc_mcontext;
|
2014-09-13 05:04:40 +02:00
|
|
|
sigset_t uc_sigmask;
|
2016-06-09 03:11:23 +02:00
|
|
|
/* Android has a wrong (smaller) sigset_t on x86. */
|
2014-09-13 05:04:40 +02:00
|
|
|
uint32_t __padding_rt_sigset;
|
2014-05-13 21:29:01 +02:00
|
|
|
struct _libc_fpstate __fpregs_mem;
|
2014-01-30 01:46:00 +01:00
|
|
|
} ucontext_t;
|
|
|
|
|
|
|
|
#elif defined(__mips__)
|
|
|
|
|
2014-01-30 03:37:15 +01:00
|
|
|
/* glibc doesn't have names for MIPS registers. */
|
|
|
|
|
|
|
|
#define NGREG 32
|
|
|
|
#define NFPREG 32
|
|
|
|
|
|
|
|
typedef unsigned long long greg_t;
|
|
|
|
typedef greg_t gregset_t[NGREG];
|
|
|
|
|
|
|
|
typedef struct fpregset {
|
|
|
|
union {
|
|
|
|
double fp_dregs[NFPREG];
|
|
|
|
struct {
|
|
|
|
float _fp_fregs;
|
|
|
|
unsigned _fp_pad;
|
|
|
|
} fp_fregs[NFPREG];
|
|
|
|
} fp_r;
|
|
|
|
} fpregset_t;
|
|
|
|
|
2015-01-05 22:27:30 +01:00
|
|
|
#ifdef __LP64__
|
|
|
|
typedef struct {
|
|
|
|
gregset_t gregs;
|
|
|
|
fpregset_t fpregs;
|
|
|
|
greg_t mdhi;
|
|
|
|
greg_t hi1;
|
|
|
|
greg_t hi2;
|
|
|
|
greg_t hi3;
|
|
|
|
greg_t mdlo;
|
|
|
|
greg_t lo1;
|
|
|
|
greg_t lo2;
|
|
|
|
greg_t lo3;
|
|
|
|
greg_t pc;
|
|
|
|
uint32_t fpc_csr;
|
|
|
|
uint32_t used_math;
|
|
|
|
uint32_t dsp;
|
|
|
|
uint32_t reserved;
|
|
|
|
} mcontext_t;
|
|
|
|
#else
|
2014-01-30 03:37:15 +01:00
|
|
|
typedef struct {
|
|
|
|
unsigned regmask;
|
|
|
|
unsigned status;
|
|
|
|
greg_t pc;
|
|
|
|
gregset_t gregs;
|
|
|
|
fpregset_t fpregs;
|
|
|
|
unsigned fp_owned;
|
|
|
|
unsigned fpc_csr;
|
|
|
|
unsigned fpc_eir;
|
|
|
|
unsigned used_math;
|
|
|
|
unsigned dsp;
|
|
|
|
greg_t mdhi;
|
|
|
|
greg_t mdlo;
|
|
|
|
unsigned long hi1;
|
|
|
|
unsigned long lo1;
|
|
|
|
unsigned long hi2;
|
|
|
|
unsigned long lo2;
|
|
|
|
unsigned long hi3;
|
|
|
|
unsigned long lo3;
|
|
|
|
} mcontext_t;
|
2015-01-05 22:27:30 +01:00
|
|
|
#endif
|
2014-01-30 03:37:15 +01:00
|
|
|
|
|
|
|
typedef struct ucontext {
|
|
|
|
unsigned long uc_flags;
|
|
|
|
struct ucontext* uc_link;
|
|
|
|
stack_t uc_stack;
|
|
|
|
mcontext_t uc_mcontext;
|
|
|
|
sigset_t uc_sigmask;
|
|
|
|
} ucontext_t;
|
2014-01-30 01:46:00 +01:00
|
|
|
|
|
|
|
#elif defined(__x86_64__)
|
2014-01-27 14:56:43 +01:00
|
|
|
|
|
|
|
enum {
|
|
|
|
REG_R8 = 0,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R8 REG_R8
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_R9,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R9 REG_R9
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_R10,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R10 REG_R10
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_R11,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R11 REG_R11
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_R12,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R12 REG_R12
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_R13,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R13 REG_R13
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_R14,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R14 REG_R14
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_R15,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_R15 REG_R15
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_RDI,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_RDI REG_RDI
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_RSI,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_RSI REG_RSI
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_RBP,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_RBP REG_RBP
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_RBX,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_RBX REG_RBX
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_RDX,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_RDX REG_RDX
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_RAX,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_RAX REG_RAX
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_RCX,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_RCX REG_RCX
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_RSP,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_RSP REG_RSP
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_RIP,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_RIP REG_RIP
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_EFL,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_EFL REG_EFL
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_CSGSFS,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_CSGSFS REG_CSGSFS
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_ERR,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_ERR REG_ERR
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_TRAPNO,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_TRAPNO REG_TRAPNO
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_OLDMASK,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_OLDMASK REG_OLDMASK
|
2014-01-27 14:56:43 +01:00
|
|
|
REG_CR2,
|
2017-06-16 00:12:29 +02:00
|
|
|
#define REG_CR2 REG_CR2
|
2014-01-27 14:56:43 +01:00
|
|
|
NGREG
|
2017-06-16 00:12:29 +02:00
|
|
|
#define NGREG NGREG
|
2014-01-27 14:56:43 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef long greg_t;
|
|
|
|
typedef greg_t gregset_t[NGREG];
|
|
|
|
|
2014-05-13 21:29:01 +02:00
|
|
|
struct _libc_fpxreg {
|
|
|
|
unsigned short significand[4];
|
|
|
|
unsigned short exponent;
|
|
|
|
unsigned short padding[3];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct _libc_xmmreg {
|
|
|
|
uint32_t element[4];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct _libc_fpstate {
|
|
|
|
uint16_t cwd;
|
|
|
|
uint16_t swd;
|
|
|
|
uint16_t ftw;
|
|
|
|
uint16_t fop;
|
|
|
|
uint64_t rip;
|
|
|
|
uint64_t rdp;
|
|
|
|
uint32_t mxcsr;
|
|
|
|
uint32_t mxcr_mask;
|
|
|
|
struct _libc_fpxreg _st[8];
|
|
|
|
struct _libc_xmmreg _xmm[16];
|
|
|
|
uint32_t padding[24];
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct _libc_fpstate* fpregset_t;
|
2014-01-27 14:56:43 +01:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
gregset_t gregs;
|
|
|
|
fpregset_t fpregs;
|
2014-04-09 22:27:48 +02:00
|
|
|
unsigned long __reserved1[8];
|
2014-01-27 14:56:43 +01:00
|
|
|
} mcontext_t;
|
|
|
|
|
|
|
|
typedef struct ucontext {
|
|
|
|
unsigned long uc_flags;
|
|
|
|
struct ucontext* uc_link;
|
|
|
|
stack_t uc_stack;
|
|
|
|
mcontext_t uc_mcontext;
|
|
|
|
sigset_t uc_sigmask;
|
2014-05-13 21:29:01 +02:00
|
|
|
struct _libc_fpstate __fpregs_mem;
|
2014-01-27 14:56:43 +01:00
|
|
|
} ucontext_t;
|
|
|
|
|
2014-01-30 01:46:00 +01:00
|
|
|
#endif
|
2014-01-27 14:56:43 +01:00
|
|
|
|
|
|
|
__END_DECLS
|
|
|
|
|
|
|
|
#endif /* _SYS_UCONTEXT_H_ */
|