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.11 2015/01/26 04:47:53 nonaka Exp $

#-
# Copyright (c) 2010, 2011 The NetBSD Foundation, Inc.
# All rights reserved.
#
# This code is derived from software contributed to The NetBSD Foundation
# by Raytheon BBN Technologies Corp and Defense Advanced Research Projects
# Agency and which was developed by Matt Thomas of 3am Software Foundry.
#
# This material is based upon work supported by the Defense Advanced Research
# Projects Agency and Space and Naval Warfare Systems Center, Pacific, under
# Contract No. N66001-09-C-2073.
# Approved for Public Release, Distribution Unlimited
#
# Copyright (c) 2010 The NetBSD Foundation, Inc.
# All rights reserved.
#
# This code is derived from software contributed to The NetBSD Foundation
# by Matt Thomas of 3am Software Foundry.
#
# 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 "opt_multiprocessor.h"

include <sys/param.h>
include <sys/bitops.h>

include <uvm/uvm_extern.h>

include <machine/frame.h>
include <machine/psl.h>
include <machine/pmap.h>

include <powerpc/booke/trap.h>
include <powerpc/booke/pte.h>

define	FRAME_DEAR	offsetof(struct ktrapframe, ktf_tf.tf_dear)
define	FRAME_ESR	offsetof(struct ktrapframe, ktf_tf.tf_esr)
define	FRAME_MCSR	offsetof(struct ktrapframe, ktf_tf.tf_mcsr)
define	FRAME_MCAR	offsetof(struct ktrapframe, ktf_tf.tf_mcar)
define	FRAME_SPRG1	offsetof(struct ktrapframe, ktf_tf.tf_sprg1)
define	FRAME_SPEFSCR	offsetof(struct ktrapframe, ktf_tf.tf_spefscr)
define	FRAME_CFRAME_LR	offsetof(struct ktrapframe, ktf_cframe_lr)

define	CI_SAVELIFO	offsetof(struct cpu_info, ci_savearea[0])
define	CI_PMAP_SEGTAB	offsetof(struct cpu_info, ci_pmap_segtabs[0])
define	CI_EV_TLBMISS_SOFT offsetof(struct cpu_info, ci_ev_tlbmiss_soft.ev_count)

define	PAGE_SIZE	PAGE_SIZE
define	PAGE_MASK	PAGE_MASK
define	PAGE_SHIFT	PAGE_SHIFT
define	KERNEL_PID	KERNEL_PID
define	USPACE		USPACE

define	T_CRITIAL_INPUT		T_CRITIAL_INPUT
define	T_MACHINE_CHECK		T_MACHINE_CHECK
define	T_DSI			T_DSI
define	T_ISI			T_ISI
define	T_EXTERNAL_INPUT	T_EXTERNAL_INPUT
define	T_ALIGNMENT		T_ALIGNMENT
define	T_PROGRAM		T_PROGRAM
define	T_FP_UNAVAILABLE	T_FP_UNAVAILABLE
define	T_SYSTEM_CALL		T_SYSTEM_CALL
define	T_AP_UNAVAILABLE	T_AP_UNAVAILABLE
define	T_DECREMENTER		T_DECREMENTER
define	T_FIXED_INTERVAL	T_FIXED_INTERVAL
define	T_WATCHDOG		T_WATCHDOG
define	T_DATA_TLB_ERROR	T_DATA_TLB_ERROR
define	T_INSTRUCTION_TLB_ERROR	T_INSTRUCTION_TLB_ERROR
define	T_DEBUG			T_DEBUG
define	T_SPE_UNAVAILABLE	T_SPE_UNAVAILABLE
define	T_EMBEDDED_FP_DATA	T_EMBEDDED_FP_DATA
define	T_EMBEDDED_FP_ROUND	T_EMBEDDED_FP_ROUND
define	T_EMBEDDED_PERF_MONITOR	T_EMBEDDED_PERF_MONITOR
define	T_AST			T_AST

define	PTE_SCALESHIFT	ilog2(sizeof(pt_entry_t))
define	PTR_SCALESHIFT	ilog2(sizeof(void *))
define	NSEGPG_SCALESHIFT	PAGE_SHIFT - ilog2(sizeof(void *))
define	NPTEPG_SCALESHIFT	PAGE_SHIFT - ilog2(sizeof(pt_entry_t))

define	MSR_DS		31 - ilog2(PSL_DS)
define	MSR_IS		31 - ilog2(PSL_IS)

ifdef MULTIPROCESSOR
define	HATCH_CI		offsetof(struct cpu_hatch_data, hatch_ci)
define	HATCH_HID0		offsetof(struct cpu_hatch_data, hatch_hid0)
define	HATCH_RUNNING		offsetof(struct cpu_hatch_data, hatch_running)
define	HATCH_SP		offsetof(struct cpu_hatch_data, hatch_sp)
define	HATCH_TBU		offsetof(struct cpu_hatch_data, hatch_tbu)
define	HATCH_TBL		offsetof(struct cpu_hatch_data, hatch_tbl)
define	HATCH_TLBIDX		offsetof(struct cpu_hatch_data, hatch_tlbidx)

define	__SIMPLELOCK_LOCKED	__SIMPLELOCK_LOCKED
define	__SIMPLELOCK_UNLOCKED	__SIMPLELOCK_UNLOCKED
endif