summaryrefslogtreecommitdiff
path: root/sys/arch/sparc64
diff options
context:
space:
mode:
authorArtur Grabowski <art@cvs.openbsd.org>2001-09-06 10:45:42 +0000
committerArtur Grabowski <art@cvs.openbsd.org>2001-09-06 10:45:42 +0000
commit990d5c499202fe863e49020b1a82c38e3800d292 (patch)
tree4e36639a26c91a01e74d9e1acdd006ecb00e5bd3 /sys/arch/sparc64
parent32ca56043a0808295738bbe95f23ef89463c5b7c (diff)
Some glue for COMPAT_NETBSD
Diffstat (limited to 'sys/arch/sparc64')
-rw-r--r--sys/arch/sparc64/include/netbsd_machdep.h22
-rw-r--r--sys/arch/sparc64/sparc64/genassym.cf10
-rw-r--r--sys/arch/sparc64/sparc64/locore.s6
-rw-r--r--sys/arch/sparc64/sparc64/netbsd_machdep.c302
-rw-r--r--sys/arch/sparc64/sparc64/sigcode_netbsd.s150
5 files changed, 489 insertions, 1 deletions
diff --git a/sys/arch/sparc64/include/netbsd_machdep.h b/sys/arch/sparc64/include/netbsd_machdep.h
new file mode 100644
index 00000000000..1081611f25b
--- /dev/null
+++ b/sys/arch/sparc64/include/netbsd_machdep.h
@@ -0,0 +1,22 @@
+/* $OpenBSD: netbsd_machdep.h,v 1.1 2001/09/06 10:45:41 art Exp $ */
+
+#ifndef _NETBSD_MACHDEP_H
+#define _NETBSD_MACHDEP_H
+
+struct netbsd_sigcontext {
+ int sc_onstack;
+ int __sc_mask13;
+ long sc_sp;
+ long sc_pc;
+ long sc_npc;
+ long sc_tstate;
+ long sc_g1;
+ long sc_o0;
+ netbsd_sigset_t sc_mask;
+};
+
+#ifdef _KERNEL
+void netbsd_sendsig __P((sig_t, int, int, u_long, int, union sigval));
+#endif
+
+#endif /* _NETBSD_MACHDEP_H */
diff --git a/sys/arch/sparc64/sparc64/genassym.cf b/sys/arch/sparc64/sparc64/genassym.cf
index 1f7622f285c..8be71d9a3fc 100644
--- a/sys/arch/sparc64/sparc64/genassym.cf
+++ b/sys/arch/sparc64/sparc64/genassym.cf
@@ -104,6 +104,10 @@ include <machine/reg.h>
#include <sparc64/sparc64/cpuvar.h>
+ifdef COMPAT_NETBSD
+include <compat/netbsd/netbsd_syscall.h>
+endif
+
ifdef notyet
include <sparc64/dev/zsreg.h>
include <sparc64/dev/zsvar.h>
@@ -274,3 +278,9 @@ define DBR_OUT offsetof(struct db_regs, dbr_out)
define DBR_LOCAL offsetof(struct db_regs, dbr_local)
define DBR_IN offsetof(struct db_regs, dbr_in)
endif
+
+ifdef COMPAT_NETBSD
+define NETBSD_SYS___sigreturn14 NETBSD_SYS___sigreturn14
+define NETBSD_SYS_exit NETBSD_SYS_exit
+endif
+
diff --git a/sys/arch/sparc64/sparc64/locore.s b/sys/arch/sparc64/sparc64/locore.s
index 8aa6d83baa3..dabcdfabd05 100644
--- a/sys/arch/sparc64/sparc64/locore.s
+++ b/sys/arch/sparc64/sparc64/locore.s
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.s,v 1.6 2001/09/04 16:51:18 jason Exp $ */
+/* $OpenBSD: locore.s,v 1.7 2001/09/06 10:45:41 art Exp $ */
/* $NetBSD: locore.s,v 1.137 2001/08/13 06:10:10 jdolecek Exp $ */
/*
@@ -6378,6 +6378,10 @@ _C_LABEL(sigcode):
_C_LABEL(esigcode):
#endif
+#ifdef COMPAT_NETBSD
+#include "sigcode_netbsd.s"
+#endif
+
#if !defined(_LP64)
#define SIGCODE_NAME sigcode
diff --git a/sys/arch/sparc64/sparc64/netbsd_machdep.c b/sys/arch/sparc64/sparc64/netbsd_machdep.c
new file mode 100644
index 00000000000..5dcf8adfa42
--- /dev/null
+++ b/sys/arch/sparc64/sparc64/netbsd_machdep.c
@@ -0,0 +1,302 @@
+/* $OpenBSD: netbsd_machdep.c,v 1.1 2001/09/06 10:45:41 art Exp $ */
+
+/*-
+ * Copyright (c) 1996, 1997, 1998 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Jason R. Thorpe of the Numerical Aerospace Simulation Facility,
+ * NASA Ames Research Center.
+ *
+ * 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.
+ *
+ * @(#)machdep.c 8.6 (Berkeley) 1/14/94
+ */
+
+#include <sys/param.h>
+#include <sys/systm.h>
+#include <sys/signalvar.h>
+#include <sys/kernel.h>
+#include <sys/exec.h>
+#include <sys/proc.h>
+#include <sys/buf.h>
+#include <sys/mount.h>
+#include <sys/syscallargs.h>
+#include <sys/user.h>
+#include <machine/cpu.h>
+
+#include <vm/vm.h>
+
+#include <compat/netbsd/netbsd_types.h>
+#include <compat/netbsd/netbsd_signal.h>
+#include <compat/netbsd/netbsd_syscallargs.h>
+
+#include <machine/netbsd_machdep.h>
+#include <machine/signal.h>
+#include <machine/frame.h>
+#include <machine/cpu.h>
+#include <machine/pmap.h>
+#include <machine/openfirm.h>
+#include <machine/sparc64.h>
+
+#include <sparc64/sparc64/cache.h>
+
+
+#ifdef DEBUG
+extern int sigdebug;
+extern int sigpid;
+#define SDB_FOLLOW 0x01
+#define SDB_KSTACK 0x02
+#endif
+
+struct netbsd_sigframe {
+ int sf_signo; /* signal number */
+ int sf_code; /* code */
+#ifndef __arch64__
+ struct sigcontext *sf_scp; /* SunOS user addr of sigcontext */
+ int sf_addr; /* SunOS compat, always 0 for now */
+#endif
+ struct netbsd_sigcontext sf_sc; /* actual sigcontext */
+};
+
+#ifdef __arch64__
+#define STACK_OFFSET BIAS
+#define CPOUTREG(l,v) copyout(&(v), (l), sizeof(v))
+#undef CCFSZ
+#define CCFSZ CC64FSZ
+#else
+#define STACK_OFFSET 0
+#define CPOUTREG(l,v) copyout(&(v), (l), sizeof(v))
+#endif
+
+/*
+ * Send an interrupt to process.
+ */
+void
+netbsd_sendsig(catcher, sig, mask, code, type, val)
+ sig_t catcher;
+ int sig, mask;
+ u_long code;
+ int type;
+ union sigval val;
+{
+ struct proc *p = curproc;
+ struct sigacts *psp = p->p_sigacts;
+ struct trapframe64 *tf;
+ vaddr_t addr;
+ struct rwindow *oldsp, *newsp;
+ struct netbsd_sigframe sf, *fp;
+ int onstack;
+ extern char netbsd_sigcode[], netbsd_esigcode[];
+#define szsigcode (netbsd_esigcode - netbsd_sigcode)
+
+ tf = p->p_md.md_tf;
+ oldsp = (struct rwindow *)(u_long)(tf->tf_out[6] + STACK_OFFSET);
+
+ /*
+ * Compute new user stack addresses, subtract off
+ * one signal frame, and align.
+ */
+ onstack = psp->ps_sigstk.ss_flags & SS_ONSTACK;
+
+ if ((psp->ps_flags & SAS_ALTSTACK) && !onstack &&
+ (psp->ps_sigonstack & sigmask(sig))) {
+ fp = (struct netbsd_sigframe *)((caddr_t)psp->ps_sigstk.ss_sp +
+ psp->ps_sigstk.ss_size);
+ psp->ps_sigstk.ss_flags = SS_ONSTACK;
+ } else
+ fp = (struct netbsd_sigframe *)oldsp;
+ /* Allocate an aligned sigframe */
+ fp = (struct netbsd_sigframe *)((long)(fp - 1) & ~0x0f);
+
+ /*
+ * Now set up the signal frame. We build it in kernel space
+ * and then copy it out. We probably ought to just build it
+ * directly in user space....
+ */
+ sf.sf_signo = sig;
+ sf.sf_code = 0; /* XXX */
+#ifndef __arch64__
+ sf.sf_scp = 0;
+ sf.sf_addr = 0; /* XXX */
+#endif
+
+ /*
+ * Build the signal context to be used by sigreturn.
+ */
+ sf.sf_sc.sc_onstack = onstack;
+ sf.sf_sc.sc_mask.__bits[0] = mask;
+ /* Save register context. */
+ sf.sf_sc.sc_sp = (long)tf->tf_out[6];
+ sf.sf_sc.sc_pc = tf->tf_pc;
+ sf.sf_sc.sc_npc = tf->tf_npc;
+#ifdef __arch64__
+ sf.sf_sc.sc_tstate = tf->tf_tstate; /* XXX */
+#else
+ sf.sf_sc.sc_psr = TSTATECCR_TO_PSR(tf->tf_tstate); /* XXX */
+#endif
+ sf.sf_sc.sc_g1 = tf->tf_global[1];
+ sf.sf_sc.sc_o0 = tf->tf_out[0];
+
+ /*
+ * Put the stack in a consistent state before we whack away
+ * at it. Note that write_user_windows may just dump the
+ * registers into the pcb; we need them in the process's memory.
+ * We also need to make sure that when we start the signal handler,
+ * its %i6 (%fp), which is loaded from the newly allocated stack area,
+ * joins seamlessly with the frame it was in when the signal occurred,
+ * so that the debugger and _longjmp code can back up through it.
+ */
+ newsp = (struct rwindow *)((vaddr_t)fp - sizeof(struct rwindow));
+ write_user_windows();
+ /* XXX do not copyout siginfo if not needed */
+ if (rwindow_save(p) || copyout((caddr_t)&sf, (caddr_t)fp, sizeof sf) ||
+ CPOUTREG(&(((struct rwindow *)newsp)->rw_in[6]), tf->tf_out[6])) {
+ /*
+ * Process has trashed its stack; give it an illegal
+ * instruction to halt it in its tracks.
+ */
+ sigexit(p, SIGILL);
+ /* NOTREACHED */
+ }
+
+ /*
+ * Arrange to continue execution at the code copied out in exec().
+ * It needs the function to call in %g1, and a new stack pointer.
+ */
+ addr = (vaddr_t)PS_STRINGS - szsigcode;
+ tf->tf_global[1] = (vaddr_t)catcher;
+ tf->tf_pc = addr;
+ tf->tf_npc = addr + 4;
+ tf->tf_out[6] = (vaddr_t)newsp - STACK_OFFSET;
+}
+
+/* ARGSUSED */
+int
+netbsd_sys___sigreturn14(p, v, retval)
+ struct proc *p;
+ void *v;
+ register_t *retval;
+{
+ struct netbsd_sys___sigreturn14_args /* {
+ syscallarg(struct netbsd_sigcontext *) sigcntxp;
+ } */ *uap = v;
+ struct netbsd_sigcontext *scp, nbsc;
+ struct trapframe64 *tf;
+
+ write_user_windows();
+
+ scp = SCARG(uap, sigcntxp);
+#ifdef DEBUG
+ if (sigdebug & SDB_FOLLOW)
+ printf("netbsd__sys___sigreturn: pid %d, scp %p\n",
+ p->p_pid, scp);
+#endif
+ if (ALIGN(scp) != (u_int64_t)scp)
+ return (EINVAL);
+
+ if (copyin((caddr_t)scp, (caddr_t)&nbsc, sizeof (nbsc)))
+ return (EFAULT);
+
+ tf = p->p_md.md_tf;
+ /*
+ * Only the icc bits in the psr are used, so it need not be
+ * verified. pc and npc must be multiples of 4. This is all
+ * that is required; if it holds, just do it.
+ */
+ if (((nbsc.sc_pc | nbsc.sc_npc) & 3) != 0 ||
+ (nbsc.sc_pc == 0) || (nbsc.sc_npc == 0))
+ return (EINVAL);
+ /* take only psr ICC field */
+#ifdef __arch64__
+ tf->tf_tstate = (u_int64_t)(tf->tf_tstate & ~TSTATE_CCR) |
+ (scp->sc_tstate & TSTATE_CCR);
+#else
+ tf->tf_tstate = (u_int64_t)(tf->tf_tstate & ~TSTATE_CCR) |
+ PSRCC_TO_TSTATE(scp->sc_psr);
+#endif
+ tf->tf_pc = (u_int64_t)scp->sc_pc;
+ tf->tf_npc = (u_int64_t)scp->sc_npc;
+ tf->tf_global[1] = (u_int64_t)scp->sc_g1;
+ tf->tf_out[0] = (u_int64_t)scp->sc_o0;
+ tf->tf_out[6] = (u_int64_t)scp->sc_sp;
+
+ /* Restore signal stack. */
+ if (nbsc.sc_onstack & SS_ONSTACK)
+ p->p_sigacts->ps_sigstk.ss_flags |= SS_ONSTACK;
+ else
+ p->p_sigacts->ps_sigstk.ss_flags &= ~SS_ONSTACK;
+
+ /* Restore signal mask. */
+ p->p_sigmask = scp->sc_mask.__bits[0] & ~sigcantmask;
+
+ return (EJUSTRETURN);
+}
diff --git a/sys/arch/sparc64/sparc64/sigcode_netbsd.s b/sys/arch/sparc64/sparc64/sigcode_netbsd.s
new file mode 100644
index 00000000000..617b3630a04
--- /dev/null
+++ b/sys/arch/sparc64/sparc64/sigcode_netbsd.s
@@ -0,0 +1,150 @@
+/* $OpenBSD: sigcode_netbsd.s,v 1.1 2001/09/06 10:45:41 art Exp $ */
+/*
+ * Copyright (c) 1996-2001 Eduardo Horvath
+ * Copyright (c) 1996 Paul Kranenburg
+ * Copyright (c) 1996
+ * The President and Fellows of Harvard College.
+ * All rights reserved.
+ * 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.
+ * This product includes software developed by Harvard University.
+ *
+ * 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.
+ * This product includes software developed by Harvard University.
+ * This product includes software developed by Paul Kranenburg.
+ * 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.
+ *
+ * @(#)locore.s 8.4 (Berkeley) 12/10/93
+ */
+
+ .globl _C_LABEL(netbsd_sigcode)
+ .globl _C_LABEL(netbsd_esigcode)
+_C_LABEL(netbsd_sigcode):
+ /*
+ * XXX the `save' and `restore' below are unnecessary: should
+ * replace with simple arithmetic on %sp
+ *
+ * Make room on the stack for 64 %f registers + %fsr. This comes
+ * out to 64*4+8 or 264 bytes, but this must be aligned to a multiple
+ * of 64, or 320 bytes.
+ */
+ save %sp, -CC64FSZ - 320, %sp
+ mov %g2, %l2 ! save globals in %l registers
+ mov %g3, %l3
+ mov %g4, %l4
+ mov %g5, %l5
+ mov %g6, %l6
+ mov %g7, %l7
+ /*
+ * Saving the fpu registers is expensive, so do it iff it is
+ * enabled and dirty.
+ */
+ rd %fprs, %l0
+ btst FPRS_DL|FPRS_DU, %l0 ! All clean?
+ bz,pt %icc, 2f
+ btst FPRS_DL, %l0 ! test dl
+ bz,pt %icc, 1f
+ btst FPRS_DU, %l0 ! test du
+
+ ! fpu is enabled, oh well
+ stx %fsr, [%sp + CC64FSZ + BIAS + 0]
+ add %sp, BIAS+CC64FSZ+BLOCK_SIZE, %l0 ! Generate a pointer so we can
+ andn %l0, BLOCK_ALIGN, %l0 ! do a block store
+ stda %f0, [%l0] ASI_BLK_P
+ inc BLOCK_SIZE, %l0
+ stda %f16, [%l0] ASI_BLK_P
+1:
+ bz,pt %icc, 2f
+ add %sp, BIAS+CC64FSZ+BLOCK_SIZE, %l0 ! Generate a pointer so we can
+ andn %l0, BLOCK_ALIGN, %l0 ! do a block store
+ add %l0, 2*BLOCK_SIZE, %l0 ! and skip what we already stored
+ stda %f32, [%l0] ASI_BLK_P
+ inc BLOCK_SIZE, %l0
+ stda %f48, [%l0] ASI_BLK_P
+2:
+ membar #Sync
+ rd %y, %l1 ! in any case, save %y
+ lduw [%fp + BIAS + 128], %o0 ! sig
+ lduw [%fp + BIAS + 128 + 4], %o1 ! code
+ call %g1 ! (*sa->sa_handler)(sig,code,scp)
+ add %fp, BIAS + 128 + 8, %o2 ! scp
+
+ /*
+ * Now that the handler has returned, re-establish all the state
+ * we just saved above, then do a sigreturn.
+ */
+ btst 3, %l0 ! All clean?
+ bz,pt %icc, 2f
+ btst 1, %l0 ! test dl
+ bz,pt %icc, 1f
+ btst 2, %l0 ! test du
+
+ ldx [%sp + CC64FSZ + BIAS + 0], %fsr
+ add %sp, BIAS+CC64FSZ+BLOCK_SIZE, %l0 ! Generate a pointer so we can
+ andn %l0, BLOCK_ALIGN, %l0 ! do a block load
+ ldda [%l0] ASI_BLK_P, %f0
+ inc BLOCK_SIZE, %l0
+ ldda [%l0] ASI_BLK_P, %f16
+1:
+ bz,pt %icc, 2f
+ wr %l1, %g0, %y ! in any case, restore %y
+ add %sp, BIAS+CC64FSZ+BLOCK_SIZE, %l0 ! Generate a pointer so we can
+ andn %l0, BLOCK_ALIGN, %l0 ! do a block load
+ inc 2*BLOCK_SIZE, %l0 ! and skip what we already loaded
+ ldda [%l0] ASI_BLK_P, %f32
+ inc BLOCK_SIZE, %l0
+ ldda [%l0] ASI_BLK_P, %f48
+2:
+ mov %l2, %g2
+ mov %l3, %g3
+ mov %l4, %g4
+ mov %l5, %g5
+ mov %l6, %g6
+ mov %l7, %g7
+ membar #Sync
+
+ restore %g0, NETBSD_SYS___sigreturn14, %g1 ! get registers back & set syscall #
+ add %sp, BIAS + 128 + 8, %o0! compute scp
+! andn %o0, 0x0f, %o0
+ t ST_SYSCALL ! sigreturn(scp)
+ ! sigreturn does not return unless it fails
+ mov NETBSD_SYS_exit, %g1 ! exit(errno)
+ t ST_SYSCALL
+_C_LABEL(netbsd_esigcode):