xref: /netbsd-src/lib/libc/arch/or1k/genassym.cf (revision 27620987b8618edefe3919667fcfb2a0eb02578b)
1#	$NetBSD: genassym.cf,v 1.1 2014/09/03 19:34:25 matt Exp $
2
3#
4# Copyright (c) 2001 The NetBSD Foundation, Inc.
5# All rights reserved.
6#
7# This code is derived from software contributed to The NetBSD Foundation
8# by Matt Thomas <matt@3am-sfotware.com>.
9#
10# Redistribution and use in source and binary forms, with or without
11# modification, are permitted provided that the following conditions
12# are met:
13# 1. Redistributions of source code must retain the above copyright
14#    notice, this list of conditions and the following disclaimer.
15# 2. Redistributions in binary form must reproduce the above copyright
16#    notice, this list of conditions and the following disclaimer in the
17#    documentation and/or other materials provided with the distribution.
18#
19# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22# PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29# POSSIBILITY OF SUCH DAMAGE.
30#
31
32include <sys/types.h>
33include <sys/queue.h>
34include <sys/cpu.h>
35include <sys/signal.h>
36include <sys/ucontext.h>
37
38include <machine/frame.h>
39include <machine/setjmp.h>
40
41define UC_GREGS_SP	offsetof(ucontext_t, uc_mcontext.__gregs[_REG_SP])
42define UC_GREGS_RV	offsetof(ucontext_t, uc_mcontext.__gregs[_REG_RV])
43define UC_GREGS_PC	offsetof(ucontext_t, uc_mcontext.__gregs[_REG_PC])
44
45define SIG_BLOCK	SIG_BLOCK
46define SIG_SETMASK	SIG_SETMASK
47
48define JBLEN          32 * sizeof(_BSD_JBSLOT_T_)
49define JB_MAGIC       0 * sizeof(_BSD_JBSLOT_T_)
50define JB_SP          1 * sizeof(_BSD_JBSLOT_T_)
51define JB_FP          2 * sizeof(_BSD_JBSLOT_T_)
52define JB_LR          3 * sizeof(_BSD_JBSLOT_T_)
53define JB_R10         4 * sizeof(_BSD_JBSLOT_T_)
54define JB_R14         5 * sizeof(_BSD_JBSLOT_T_)
55define JB_R16         6 * sizeof(_BSD_JBSLOT_T_)
56define JB_R18         7 * sizeof(_BSD_JBSLOT_T_)
57define JB_R20         8 * sizeof(_BSD_JBSLOT_T_)
58define JB_R22         9 * sizeof(_BSD_JBSLOT_T_)
59define JB_R24         10 * sizeof(_BSD_JBSLOT_T_)
60define JB_R26         11 * sizeof(_BSD_JBSLOT_T_)
61define JB_R28         12 * sizeof(_BSD_JBSLOT_T_)
62define JB_R30         13 * sizeof(_BSD_JBSLOT_T_)
63define JB_PC          14 * sizeof(_BSD_JBSLOT_T_)
64define JB_SIGMASK     15 * sizeof(_BSD_JBSLOT_T_)
65