Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

#	$NetBSD: genassym.cf,v 1.1 2014/09/03 19:34:25 matt Exp $

#
# Copyright (c) 2001 The NetBSD Foundation, Inc.
# All rights reserved.
#
# This code is derived from software contributed to The NetBSD Foundation
# by Matt Thomas <matt@3am-sfotware.com>.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
#    notice, this list of conditions and the following disclaimer.
# 2. 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 NETBSD FOUNDATION, INC. 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 FOUNDATION 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.
#

include <sys/types.h>
include <sys/queue.h>
include <sys/cpu.h>
include <sys/signal.h>
include <sys/ucontext.h>

include <machine/frame.h>
include <machine/setjmp.h>

define UC_GREGS_SP	offsetof(ucontext_t, uc_mcontext.__gregs[_REG_SP])
define UC_GREGS_RV	offsetof(ucontext_t, uc_mcontext.__gregs[_REG_RV])
define UC_GREGS_PC	offsetof(ucontext_t, uc_mcontext.__gregs[_REG_PC])

define SIG_BLOCK	SIG_BLOCK
define SIG_SETMASK	SIG_SETMASK

define JBLEN          32 * sizeof(_BSD_JBSLOT_T_)
define JB_MAGIC       0 * sizeof(_BSD_JBSLOT_T_)
define JB_SP          1 * sizeof(_BSD_JBSLOT_T_)
define JB_FP          2 * sizeof(_BSD_JBSLOT_T_)
define JB_LR          3 * sizeof(_BSD_JBSLOT_T_)
define JB_R10         4 * sizeof(_BSD_JBSLOT_T_)
define JB_R14         5 * sizeof(_BSD_JBSLOT_T_)
define JB_R16         6 * sizeof(_BSD_JBSLOT_T_)
define JB_R18         7 * sizeof(_BSD_JBSLOT_T_)
define JB_R20         8 * sizeof(_BSD_JBSLOT_T_)
define JB_R22         9 * sizeof(_BSD_JBSLOT_T_)
define JB_R24         10 * sizeof(_BSD_JBSLOT_T_)
define JB_R26         11 * sizeof(_BSD_JBSLOT_T_)
define JB_R28         12 * sizeof(_BSD_JBSLOT_T_)
define JB_R30         13 * sizeof(_BSD_JBSLOT_T_)
define JB_PC          14 * sizeof(_BSD_JBSLOT_T_)
define JB_SIGMASK     15 * sizeof(_BSD_JBSLOT_T_)