NetBSD/sys/arch/sparc64/sparc64/genassym.cf

277 lines
10 KiB
CFEngine3

# $NetBSD: genassym.cf,v 1.8 1998/10/08 02:31:40 eeh Exp $
#
# Copyright (c) 1997 The NetBSD Foundation, Inc.
# All rights reserved.
#
# This code is derived from software contributed to The NetBSD Foundation
# by Christos Zoulas.
#
# 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.
# 3. All advertising materials mentioning features or use of this software
# must display the following acknowledgement:
# This product includes software developed by the NetBSD
# Foundation, Inc. and its contributors.
# 4. Neither the name of The NetBSD Foundation nor the names of its
# contributors may be used to endorse or promote products derived
# from this software without specific prior written permission.
#
# 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.
#
# Copyright (c) 1992, 1993
# The Regents of the University of California. All rights reserved.
#
# This software was developed by the Computer Systems Engineering group
# at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and
# contributed to Berkeley.
#
# All advertising materials mentioning features or use of this software
# must display the following acknowledgement:
# This product includes software developed by the University of
# California, Lawrence Berkeley Laboratory.
#
# 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.
# 3. All advertising materials mentioning features or use of this software
# must display the following acknowledgement:
# This product includes software developed by the University of
# California, Berkeley and its contributors.
# 4. Neither the name of the University nor the names of its contributors
# may be used to endorse or promote products derived from this software
# without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
#
# @(#)genassym.c 8.1 (Berkeley) 6/11/93
#
include <sys/param.h>
include <sys/buf.h>
include <sys/proc.h>
include <sys/map.h>
include <sys/proc.h>
include <sys/mbuf.h>
include <sys/msgbuf.h>
include <sys/syscall.h>
include <sys/user.h>
include <sys/device.h>
include <sys/disklabel.h>
include <sys/disk.h>
include <machine/db_machdep.h>
include <machine/pmap.h>
include <machine/cpu.h>
include <machine/bsd_openprom.h>
include <machine/reg.h>
#include <sparc64/sparc64/cpuvar.h>
ifdef notyet
include <sparc64/dev/zsreg.h>
include <sparc64/dev/zsvar.h>
endif
ifdef notyet
include <dev/ic/am7930reg.h>
include <dev/ic/am7930var.h>
endif
include <sparc64/dev/fdreg.h>
include <sparc64/dev/fdvar.h>
# general constants
define BSD BSD
define USRSTACK USRSTACK
define PADDRT sizeof(paddr_t)
# proc fields and values
define P_ADDR offsetof(struct proc, p_addr)
define P_STAT offsetof(struct proc, p_stat)
define P_WCHAN offsetof(struct proc, p_wchan)
define P_VMSPACE offsetof(struct proc, p_vmspace)
define P_PID offsetof(struct proc, p_pid)
define SRUN SRUN
# user structure fields
define USIZ sizeof(struct user)
# VM structure fields
define VM_PMAP offsetof(struct vmspace, vm_map.pmap)
#define VM_PMAP_CTX offsetof(struct vmspace, vm_map.pmap.pm_ctx)
# pmap structure fields
define PM_CTX offsetof(struct pmap, pm_ctx)
define PM_SEGS offsetof(struct pmap, pm_segs)
define PM_PHYS offsetof(struct pmap, pm_physaddr)
# interrupt/fault metering
ifdef UVM
define V_SWTCH offsetof(struct uvmexp, swtch)
define V_INTR offsetof(struct uvmexp, intrs)
define V_FAULTS offsetof(struct uvmexp, faults)
else
define V_SWTCH offsetof(struct vmmeter, v_swtch)
define V_INTR offsetof(struct vmmeter, v_intr)
define V_FAULTS offsetof(struct vmmeter, v_faults)
endif
# CPU info structure
#define CPUINFO_FAULTSTATUS offsetof(struct cpu_softc, get_faultstatus)
# FPU state
define FS_REGS offsetof(struct fpstate, fs_regs)
define FS_FSR offsetof(struct fpstate, fs_fsr)
define FS_QSIZE offsetof(struct fpstate, fs_qsize)
define FS_QUEUE offsetof(struct fpstate, fs_queue)
define FSR_QNE FSR_QNE
define FPRS_FEF FPRS_FEF
# system calls
define SYS___sigreturn14 SYS___sigreturn14
define SYS_execve SYS_execve
define SYS_exit SYS_exit
# errno
define EFAULT EFAULT
define ENAMETOOLONG ENAMETOOLONG
# PCB fields
define PCB_NSAVED offsetof(struct pcb, pcb_nsaved)
define PCB_ONFAULT offsetof(struct pcb, pcb_onfault)
define PCB_PSTATE offsetof(struct pcb, pcb_pstate)
define PCB_CWP offsetof(struct pcb, pcb_cwp)
define PCB_PIL offsetof(struct pcb, pcb_pil)
define PCB_RW offsetof(struct pcb, pcb_rw)
define PCB_SP offsetof(struct pcb, pcb_sp)
define PCB_PC offsetof(struct pcb, pcb_pc)
define PCB_LASTCALL offsetof(struct pcb, lastcall)
define PCB_SIZE sizeof(struct pcb)
# trapframe fields
define TF_TSTATE offsetof(struct trapframe, tf_tstate)
define TF_PC offsetof(struct trapframe, tf_pc)
define TF_NPC offsetof(struct trapframe, tf_npc)
define TF_FAULT offsetof(struct trapframe, tf_fault)
define TF_KSTACK offsetof(struct trapframe, tf_kstack)
define TF_Y offsetof(struct trapframe, tf_y)
define TF_PIL offsetof(struct trapframe, tf_pil)
define TF_OLDPIL offsetof(struct trapframe, tf_oldpil)
define TF_TT offsetof(struct trapframe, tf_tt)
define TF_GLOBAL offsetof(struct trapframe, tf_global)
define TF_OUT offsetof(struct trapframe, tf_out)
define TF_LOCAL offsetof(struct trapframe, tf_local)
define TF_IN offsetof(struct trapframe, tf_in)
# shortened versions
define TF_G offsetof(struct trapframe, tf_global)
define TF_O offsetof(struct trapframe, tf_out)
define TF_L offsetof(struct trapframe, tf_local)
define TF_I offsetof(struct trapframe, tf_in)
define TF_SIZE sizeof(struct trapframe)
ifdef notyet
# clockframe fields
define CF_TSTATE offsetof(struct clockframe, tstate)
define CF_PC offsetof(struct clockframe, pc)
define CF_NPC offsetof(struct clockframe, npc)
define CF_PIL offsetof(struct clockframe, pil)
define CF_OLDPIL offsetof(struct clockframe, oldpil)
define CF_FP offsetof(struct clockframe, fp)
endif
# interrupt handler fields */
define IH_FUN offsetof(struct intrhand, ih_fun)
define IH_ARG offsetof(struct intrhand, ih_arg)
define IH_NUMBER offsetof(struct intrhand, ih_number)
define IH_PIL offsetof(struct intrhand, ih_pil)
define IH_NEXT offsetof(struct intrhand, ih_next)
define IH_MAP offsetof(struct intrhand, ih_map)
define IH_CLR offsetof(struct intrhand, ih_clr)
ifdef notyet
# ZSCC interrupt fields
define ZSC_A offsetof(struct zs_softc, sc_a)
define ZSC_B offsetof(struct zs_softc, sc_b)
#define ZL_WREG offsetof(struct zs_line, zl_wreg)
define ZL_TBC offsetof(struct zs_line, zl_tbc)
define ZL_TBA offsetof(struct zs_line, zl_tba)
define ZL_RBPUT offsetof(struct zs_line, zl_rbput)
define ZL_RBUF offsetof(struct zs_line, zl_rbuf)
define ZSRR1_DO_bit ffs(ZSRR1_DO) - 1
endif
ifdef notyet
# audio trap handler fields
define AU_AMD offsetof(struct auio, au_amd)
define AU_RDATA offsetof(struct auio, au_rdata)
define AU_REND offsetof(struct auio, au_rend)
define AU_PDATA offsetof(struct auio, au_pdata)
define AU_PEND offsetof(struct auio, au_pend)
define AU_EVCNT offsetof(struct auio, au_intrcnt.ev_count)
define AMD_IR offsetof(struct amd7930, ir)
define AMD_BBRB offsetof(struct amd7930, bbrb)
define AMD_BBTB offsetof(struct amd7930, bbtb)
endif
#define PROM_BASE PROM_BASE
define PV_NODEOPS offsetof(struct promvec, pv_nodeops)
define PV_HALT offsetof(struct promvec, pv_halt)
define PV_EVAL offsetof(struct promvec, pv_fortheval.v0_eval)
define PV_ROMVEC_VERS offsetof(struct promvec, pv_romvec_vers)
define NO_NEXTNODE offsetof(struct nodeops, no_nextnode)
define NO_GETPROP offsetof(struct nodeops, no_getprop)
ifdef notyet
define OLDMON_PRINTF offsetof(struct om_vector, printf)
define OLDMON_HALT offsetof(struct om_vector, exitToMon)
endif
# floppy trap handler fields
define FDC_REG_MSR offsetof(struct fdcio, fdcio_reg_msr)
define FDC_REG_FIFO offsetof(struct fdcio, fdcio_reg_fifo)
define FDC_ISTATE offsetof(struct fdcio, fdcio_istate)
define FDC_STATUS offsetof(struct fdcio, fdcio_status)
define FDC_NSTAT offsetof(struct fdcio, fdcio_nstat)
define FDC_DATA offsetof(struct fdcio, fdcio_data)
define FDC_TC offsetof(struct fdcio, fdcio_tc)
define FDC_EVCNT offsetof(struct fdcio, fdcio_intrcnt.ev_count)