Home | History | Annotate | Line # | Download | only in include
mcontext.h revision 1.9.4.2
      1  1.9.4.2     yamt /*	$NetBSD: mcontext.h,v 1.9.4.2 2012/10/30 17:19:04 yamt Exp $	*/
      2      1.2  thorpej 
      3      1.2  thorpej /*-
      4      1.2  thorpej  * Copyright (c) 2001, 2002 The NetBSD Foundation, Inc.
      5      1.2  thorpej  * All rights reserved.
      6      1.2  thorpej  *
      7      1.2  thorpej  * This code is derived from software contributed to The NetBSD Foundation
      8      1.2  thorpej  * by Klaus Klein and by Jason R. Thorpe of Wasabi Systems, Inc.
      9      1.2  thorpej  *
     10      1.2  thorpej  * Redistribution and use in source and binary forms, with or without
     11      1.2  thorpej  * modification, are permitted provided that the following conditions
     12      1.2  thorpej  * are met:
     13      1.2  thorpej  * 1. Redistributions of source code must retain the above copyright
     14      1.2  thorpej  *    notice, this list of conditions and the following disclaimer.
     15      1.2  thorpej  * 2. Redistributions in binary form must reproduce the above copyright
     16      1.2  thorpej  *    notice, this list of conditions and the following disclaimer in the
     17      1.2  thorpej  *    documentation and/or other materials provided with the distribution.
     18      1.2  thorpej  *
     19      1.2  thorpej  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     20      1.2  thorpej  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     21      1.2  thorpej  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     22      1.2  thorpej  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     23      1.2  thorpej  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     24      1.2  thorpej  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     25      1.2  thorpej  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     26      1.2  thorpej  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     27      1.2  thorpej  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     28      1.2  thorpej  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     29      1.2  thorpej  * POSSIBILITY OF SUCH DAMAGE.
     30      1.2  thorpej  */
     31      1.2  thorpej 
     32      1.2  thorpej #ifndef _ARM_MCONTEXT_H_
     33      1.2  thorpej #define _ARM_MCONTEXT_H_
     34      1.2  thorpej 
     35      1.2  thorpej /*
     36      1.2  thorpej  * General register state
     37      1.2  thorpej  */
     38      1.2  thorpej #define _NGREG		17
     39      1.2  thorpej typedef unsigned int	__greg_t;
     40      1.2  thorpej typedef __greg_t	__gregset_t[_NGREG];
     41      1.2  thorpej 
     42      1.2  thorpej #define _REG_R0		0
     43      1.2  thorpej #define _REG_R1		1
     44      1.2  thorpej #define _REG_R2		2
     45      1.2  thorpej #define _REG_R3		3
     46      1.2  thorpej #define _REG_R4		4
     47      1.2  thorpej #define _REG_R5		5
     48      1.2  thorpej #define _REG_R6		6
     49      1.2  thorpej #define _REG_R7		7
     50      1.2  thorpej #define _REG_R8		8
     51      1.2  thorpej #define _REG_R9		9
     52      1.2  thorpej #define _REG_R10	10
     53      1.2  thorpej #define _REG_R11	11
     54      1.2  thorpej #define _REG_R12	12
     55      1.2  thorpej #define _REG_R13	13
     56      1.2  thorpej #define _REG_R14	14
     57      1.2  thorpej #define _REG_R15	15
     58      1.2  thorpej #define _REG_CPSR	16
     59      1.2  thorpej /* Convenience synonyms */
     60      1.2  thorpej #define _REG_FP		_REG_R11
     61      1.2  thorpej #define _REG_SP		_REG_R13
     62      1.2  thorpej #define _REG_LR		_REG_R14
     63      1.2  thorpej #define _REG_PC		_REG_R15
     64      1.2  thorpej 
     65      1.2  thorpej /*
     66      1.2  thorpej  * Floating point register state
     67      1.2  thorpej  */
     68      1.2  thorpej /* Note: the storage layout of this structure must be identical to ARMFPE! */
     69      1.2  thorpej typedef struct {
     70      1.2  thorpej 	unsigned int	__fp_fpsr;
     71      1.2  thorpej 	struct {
     72      1.2  thorpej 		unsigned int	__fp_exponent;
     73      1.2  thorpej 		unsigned int	__fp_mantissa_hi;
     74      1.2  thorpej 		unsigned int	__fp_mantissa_lo;
     75      1.2  thorpej 	}		__fp_fr[8];
     76      1.2  thorpej } __fpregset_t;
     77      1.2  thorpej 
     78      1.2  thorpej typedef struct {
     79      1.2  thorpej 	unsigned int	__vfp_fpscr;
     80      1.2  thorpej 	unsigned int	__vfp_fstmx[33];
     81      1.2  thorpej 	unsigned int	__vfp_fpsid;
     82      1.2  thorpej } __vfpregset_t;
     83      1.2  thorpej 
     84      1.2  thorpej typedef struct {
     85      1.2  thorpej 	__gregset_t	__gregs;
     86      1.2  thorpej 	union {
     87      1.2  thorpej 		__fpregset_t __fpregs;
     88      1.2  thorpej 		__vfpregset_t __vfpregs;
     89      1.2  thorpej 	} __fpu;
     90      1.8    joerg 	__greg_t	_mc_tlsbase;
     91  1.9.4.2     yamt } mcontext_t, mcontext32_t;
     92      1.2  thorpej 
     93      1.2  thorpej /* Machine-dependent uc_flags */
     94      1.2  thorpej #define	_UC_ARM_VFP	0x00010000	/* FPU field is VFP */
     95      1.3     matt 
     96      1.3     matt /* used by signal delivery to indicate status of signal stack */
     97      1.3     matt #define _UC_SETSTACK	0x00020000
     98      1.3     matt #define _UC_CLRSTACK	0x00040000
     99      1.2  thorpej 
    100      1.8    joerg #define	_UC_TLSBASE	0x00080000
    101      1.8    joerg 
    102      1.8    joerg #define _UC_MACHINE_PAD	2		/* Padding appended to ucontext_t */
    103      1.2  thorpej 
    104      1.2  thorpej #define _UC_MACHINE_SP(uc)	((uc)->uc_mcontext.__gregs[_REG_SP])
    105      1.4  thorpej #define _UC_MACHINE_PC(uc)	((uc)->uc_mcontext.__gregs[_REG_PC])
    106      1.4  thorpej #define _UC_MACHINE_INTRV(uc)	((uc)->uc_mcontext.__gregs[_REG_R0])
    107      1.4  thorpej 
    108      1.4  thorpej #define	_UC_MACHINE_SET_PC(uc, pc)	_UC_MACHINE_PC(uc) = (pc)
    109      1.2  thorpej 
    110      1.7    joerg #define	__UCONTEXT_SIZE	256
    111      1.7    joerg 
    112      1.9     matt static __inline void *
    113      1.9     matt __lwp_getprivate_fast(void)
    114      1.9     matt {
    115  1.9.4.1     yamt 	extern void *_lwp_getprivate(void);
    116      1.9     matt 	void *rv;
    117      1.9     matt 	__asm("mrc p15, 0, %0, c13, c0, 3" : "=r"(rv));
    118  1.9.4.1     yamt 	if (__predict_true(rv))
    119  1.9.4.1     yamt 		return rv;
    120  1.9.4.1     yamt 	/*
    121  1.9.4.1     yamt 	 * Some ARM cores are broken and don't raise an undefined fault when an
    122  1.9.4.1     yamt 	 * unrecogized mrc instruction is encountered, but just return zero.
    123  1.9.4.1     yamt 	 * To do deal with that, if we get a zero we (re-)fetch the value using
    124  1.9.4.1     yamt 	 * syscall.
    125  1.9.4.1     yamt 	 */
    126  1.9.4.1     yamt 	return _lwp_getprivate();
    127      1.9     matt }
    128      1.9     matt 
    129      1.2  thorpej #endif	/* !_ARM_MCONTEXT_H_ */
    130