xref: /netbsd-src/lib/libc/arch/riscv/genassym.cf (revision bdc22b2e01993381dcefeff2bc9b56ca75a4235c)
1#	$NetBSD: genassym.cf,v 1.2 2015/03/27 23:22:20 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/setjmp.h>
39
40define UC_GREGS_SP	offsetof(ucontext_t, uc_mcontext.__gregs[_REG_SP])
41define UC_GREGS_RV	offsetof(ucontext_t, uc_mcontext.__gregs[_REG_RV])
42define UC_GREGS_PC	offsetof(ucontext_t, uc_mcontext.__gregs[_REG_PC])
43
44define SIG_BLOCK	SIG_BLOCK
45define SIG_SETMASK	SIG_SETMASK
46define SIGINFO_SIZE	(sizeof(siginfo_t) + __ALIGNBYTES) & ~__ALIGNBYTES
47
48define JBLEN		_JBLEN * sizeof(_BSD_JBSLOT_T_)
49define JB_MAGIC		_JB_MAGIC * sizeof(_BSD_JBSLOT_T_)
50define JB_RA		_JB_RA * sizeof(_BSD_JBSLOT_T_)
51define JB_S0		_JB_S0 * sizeof(_BSD_JBSLOT_T_)
52define JB_S1		_JB_S1 * sizeof(_BSD_JBSLOT_T_)
53define JB_S2		_JB_S2 * sizeof(_BSD_JBSLOT_T_)
54define JB_S3		_JB_S3 * sizeof(_BSD_JBSLOT_T_)
55define JB_S4		_JB_S4 * sizeof(_BSD_JBSLOT_T_)
56define JB_S5		_JB_S5 * sizeof(_BSD_JBSLOT_T_)
57define JB_S6		_JB_S6 * sizeof(_BSD_JBSLOT_T_)
58define JB_S7		_JB_S7 * sizeof(_BSD_JBSLOT_T_)
59define JB_S8		_JB_S8 * sizeof(_BSD_JBSLOT_T_)
60define JB_S9		_JB_S9 * sizeof(_BSD_JBSLOT_T_)
61define JB_S10		_JB_S10 * sizeof(_BSD_JBSLOT_T_)
62define JB_S11		_JB_S11 * sizeof(_BSD_JBSLOT_T_)
63define JB_SP		_JB_SP * sizeof(_BSD_JBSLOT_T_)
64define JB_TP		_JB_TP * sizeof(_BSD_JBSLOT_T_)
65define JB_GP		_JB_GP * sizeof(_BSD_JBSLOT_T_)
66define JB_FCSR		_JB_FCSR * sizeof(_BSD_JBSLOT_T_)
67
68define JB_FS0		_JB_FS0 * sizeof(_BSD_JBSLOT_T_)
69define JB_FS1		_JB_FS1 * sizeof(_BSD_JBSLOT_T_)
70define JB_FS2		_JB_FS2 * sizeof(_BSD_JBSLOT_T_)
71define JB_FS3		_JB_FS3 * sizeof(_BSD_JBSLOT_T_)
72define JB_FS4		_JB_FS4 * sizeof(_BSD_JBSLOT_T_)
73define JB_FS5		_JB_FS5 * sizeof(_BSD_JBSLOT_T_)
74define JB_FS6		_JB_FS6 * sizeof(_BSD_JBSLOT_T_)
75define JB_FS7		_JB_FS7 * sizeof(_BSD_JBSLOT_T_)
76define JB_FS8		_JB_FS8 * sizeof(_BSD_JBSLOT_T_)
77define JB_FS9		_JB_FS9 * sizeof(_BSD_JBSLOT_T_)
78define JB_FS10		_JB_FS10 * sizeof(_BSD_JBSLOT_T_)
79define JB_FS11		_JB_FS11 * sizeof(_BSD_JBSLOT_T_)
80
81define JB_SIGMASK	_JB_SIGMASK * sizeof(_BSD_JBSLOT_T_)
82