Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/nathanw_sa]: src/sys/arch/alpha/alpha No need to have code we don't use ...



details:   https://anonhg.NetBSD.org/src/rev/69a60cdffdb2
branches:  nathanw_sa
changeset: 504656:69a60cdffdb2
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Sat May 05 02:20:54 2001 +0000

description:
No need to have code we don't use anymore.

diffstat:

 sys/arch/alpha/alpha/multiproc.s |  95 ++++++++++++++++++++++++++++++++++++++++
 1 files changed, 95 insertions(+), 0 deletions(-)

diffs (99 lines):

diff -r 9895f7369b8d -r 69a60cdffdb2 sys/arch/alpha/alpha/multiproc.s
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/arch/alpha/alpha/multiproc.s  Sat May 05 02:20:54 2001 +0000
@@ -0,0 +1,95 @@
+/* $NetBSD: multiproc.s,v 1.9.4.2 2001/05/05 02:20:54 thorpej Exp $ */
+
+/*-
+ * Copyright (c) 1998, 2000 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.
+ */
+
+__KERNEL_RCSID(5, "$NetBSD: multiproc.s,v 1.9.4.2 2001/05/05 02:20:54 thorpej Exp $")
+
+/*
+ * Multiprocessor glue code.
+ */
+
+       .text
+inc5:  .stabs  __FILE__,132,0,0,inc5; .loc     1 __LINE__
+
+/*
+ * cpu_spinup_trampoline:
+ *
+ * We come here via the secondary processor's console.  We simply
+ * make the function call look right, and call cpu_hatch() to finish
+ * starting up the processor.
+ *
+ * We are provided an argument in $27 (pv).  It will be a pointer to
+ * our cpu_info.
+ */
+NESTED_NOPROFILE(cpu_spinup_trampoline,0,0,ra,0,0)
+       mov     pv, s0                  /* squirrel away argument */
+
+       br      pv, 1f                  /* compute new GP */
+1:     LDGP(pv)
+
+       /* Write new KGP. */
+       mov     gp, a0
+       call_pal PAL_OSF1_wrkgp
+
+       /* Store our CPU info in SysValue. */
+       mov     s0, a0
+       call_pal PAL_OSF1_wrval
+
+       /* Switch to this CPU's idle thread. */
+       ldq     a0, CPU_INFO_IDLE_PCB_PADDR(s0)
+       SWITCH_CONTEXT
+
+       /* Invalidate TLB and I-stream. */
+       ldiq    a0, -2                  /* TBIA */
+       call_pal PAL_OSF1_tbi
+       call_pal PAL_imb
+
+       /* Make sure the FPU is turned off. */
+       mov     zero, a0
+       call_pal PAL_OSF1_wrfen
+
+       /* Restore argument and call cpu_hatch() */
+       mov     s0, a0
+       CALL(cpu_hatch)
+
+       /* Acquire the scheduler lock, and then jump into the idle loop! */
+       CALL(sched_lock_idle)
+       mov     zero, s0                /* no outgoing proc */
+       jmp     zero, idle
+
+       END(cpu_spinup_trampoline)



Home | Main Index | Thread Index | Old Index