NetBSD/sys/arch/powerpc/mpc6xx/genassym.cf
chs 810cde53cc use a completely separate trap handler for syscall traps.
this reduces syscall overhead by 10% to 20% depending on cpu type.
2002-08-02 03:46:42 +00:00

138 lines
5.9 KiB
CFEngine3

# $NetBSD: genassym.cf,v 1.6 2002/08/02 03:46:44 chs Exp $
#
# Copyright (C) 1995, 1996 Wolfgang Solfrank.
# Copyright (C) 1995, 1996 TooLs GmbH.
# All rights reserved.
#
# 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 TooLs GmbH.
# 4. The name of TooLs GmbH may not be used to endorse or promote products
# derived from this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``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 TOOLS GMBH 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/param.h>
include <sys/time.h>
include <sys/proc.h>
include <uvm/uvm_extern.h>
include <machine/pcb.h>
include <machine/pmap.h>
include <powerpc/cpu.h>
define FRAMELEN FRAMELEN
define FRAME_0 offsetof(struct trapframe, fixreg[0])
define FRAME_1 offsetof(struct trapframe, fixreg[1])
define FRAME_2 offsetof(struct trapframe, fixreg[2])
define FRAME_3 offsetof(struct trapframe, fixreg[3])
define FRAME_LR offsetof(struct trapframe, lr)
define FRAME_CR offsetof(struct trapframe, cr)
define FRAME_CTR offsetof(struct trapframe, ctr)
define FRAME_XER offsetof(struct trapframe, xer)
define FRAME_SRR0 offsetof(struct trapframe, srr0)
define FRAME_SRR1 offsetof(struct trapframe, srr1)
define FRAME_DAR offsetof(struct trapframe, dar)
define FRAME_DSISR offsetof(struct trapframe, dsisr)
define FRAME_EXC offsetof(struct trapframe, exc)
define FRAME_VRSAVE offsetof(struct trapframe, vrsave)
define IFRAMELEN IFRAMELEN
define IFRAME_R1 offsetof(struct intrframe, r1)
define IFRAME_SRR1 offsetof(struct intrframe, srr1)
define IFRAME_SRR0 offsetof(struct intrframe, srr0)
define IFRAME_PRI offsetof(struct intrframe, pri)
define IFRAME_INTR_DEPTH offsetof(struct intrframe, intrdepth)
define IFRAME_VRSAVE offsetof(struct intrframe, vrsave)
define IFRAME_CTR offsetof(struct intrframe, ctr)
define IFRAME_XER offsetof(struct intrframe, xer)
define IFRAME_CR offsetof(struct intrframe, cr)
define IFRAME_LR offsetof(struct intrframe, lr)
define IFRAME_R12 offsetof(struct intrframe, r12)
define IFRAME_R11 offsetof(struct intrframe, r11)
define IFRAME_R10 offsetof(struct intrframe, r10)
define IFRAME_R9 offsetof(struct intrframe, r9)
define IFRAME_R8 offsetof(struct intrframe, r8)
define IFRAME_R7 offsetof(struct intrframe, r7)
define IFRAME_R6 offsetof(struct intrframe, r6)
define IFRAME_R5 offsetof(struct intrframe, r5)
define IFRAME_R4 offsetof(struct intrframe, r4)
define IFRAME_R3 offsetof(struct intrframe, r3)
define IFRAME_R0 offsetof(struct intrframe, r0)
define SPFRAMELEN SPFRAMELEN
define SPFRAME_R1 offsetof(struct spillframe, r1)
define SPFRAME_R12 offsetof(struct spillframe, r12)
define SPFRAME_R11 offsetof(struct spillframe, r11)
define SPFRAME_R10 offsetof(struct spillframe, r10)
define SPFRAME_R9 offsetof(struct spillframe, r9)
define SPFRAME_R8 offsetof(struct spillframe, r8)
define SPFRAME_R7 offsetof(struct spillframe, r7)
define SPFRAME_R6 offsetof(struct spillframe, r6)
define SPFRAME_R5 offsetof(struct spillframe, r5)
define SPFRAME_R4 offsetof(struct spillframe, r4)
define SPFRAME_R3 offsetof(struct spillframe, r3)
define SPFRAME_R0 offsetof(struct spillframe, r0)
define SFRAMELEN roundup(sizeof(struct switchframe), 16)
define PCB_PMR offsetof(struct pcb, pcb_pmreal)
define PCB_SP offsetof(struct pcb, pcb_sp)
define PCB_SPL offsetof(struct pcb, pcb_spl)
define PCB_FAULT offsetof(struct pcb, pcb_onfault)
define PM_SR offsetof(struct pmap, pm_sr[0])
define PM_USRSR offsetof(struct pmap, pm_sr[USER_SR])
define PM_KERNELSR offsetof(struct pmap, pm_sr[KERNEL_SR])
define P_FORW offsetof(struct proc, p_forw)
define P_BACK offsetof(struct proc, p_back)
define P_ADDR offsetof(struct proc, p_addr)
define P_STAT offsetof(struct proc, p_stat)
define P_CPU offsetof(struct proc, p_cpu)
define P_MD_SYSCALL offsetof(struct proc, p_md.md_syscall)
define SONPROC SONPROC
define CI_SIZE sizeof(struct cpu_info)
define CI_CURPROC offsetof(struct cpu_info, ci_curproc)
define CI_CURPCB offsetof(struct cpu_info, ci_curpcb)
define CI_CURPM offsetof(struct cpu_info, ci_curpm)
define CI_IDLE_PCB offsetof(struct cpu_info, ci_idle_pcb)
define CI_ASTPENDING offsetof(struct cpu_info, ci_astpending)
define CI_WANT_RESCHED offsetof(struct cpu_info, ci_want_resched)
define CI_CPL offsetof(struct cpu_info, ci_cpl)
define CI_INTRDEPTH offsetof(struct cpu_info, ci_intrdepth)
define CI_INTSTK offsetof(struct cpu_info, ci_intstk)
define CI_SPILLSTK offsetof(struct cpu_info, ci_spillstk)
define CI_TEMPSAVE offsetof(struct cpu_info, ci_tempsave)
define CI_DDBSAVE offsetof(struct cpu_info, ci_ddbsave)
define CI_IPKDBSAVE offsetof(struct cpu_info, ci_ipkdbsave)
define CI_DISISAVE offsetof(struct cpu_info, ci_disisave)
define CACHELINESIZE CACHELINESIZE
define CPU_CI offsetof(struct cpu_info, ci_ci)