Module Name: src
Committed By: snj
Date: Fri Jun 5 18:28:34 UTC 2009
Modified Files:
src/sys/arch/sparc64/include [netbsd-5]: cpu.h
src/sys/arch/sparc64/sparc64 [netbsd-5]: locore.s vm_machdep.c
Log Message:
Pull up following revision(s) (requested by martin in ticket #786):
sys/arch/sparc64/include/cpu.h: revision 1.86
sys/arch/sparc64/sparc64/locore.s: revision 1.291
sys/arch/sparc64/sparc64/vm_machdep.c: revision 1.89
cpu_setfunc() can not use lwp_trampoline, as that has additional lwp startup
semantics. Use a simpler setfunc_trampoline instead.
To generate a diff of this commit:
cvs rdiff -u -r1.84 -r1.84.4.1 src/sys/arch/sparc64/include/cpu.h
cvs rdiff -u -r1.286 -r1.286.2.1 src/sys/arch/sparc64/sparc64/locore.s
cvs rdiff -u -r1.84.4.1 -r1.84.4.2 src/sys/arch/sparc64/sparc64/vm_machdep.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/arch/sparc64/include/cpu.h
diff -u src/sys/arch/sparc64/include/cpu.h:1.84 src/sys/arch/sparc64/include/cpu.h:1.84.4.1
--- src/sys/arch/sparc64/include/cpu.h:1.84 Sun Oct 5 01:53:05 2008
+++ src/sys/arch/sparc64/include/cpu.h Fri Jun 5 18:28:34 2009
@@ -1,4 +1,4 @@
-/* $NetBSD: cpu.h,v 1.84 2008/10/05 01:53:05 nakayama Exp $ */
+/* $NetBSD: cpu.h,v 1.84.4.1 2009/06/05 18:28:34 snj Exp $ */
/*
* Copyright (c) 1992, 1993
@@ -338,7 +338,6 @@
#define write_all_windows() __asm volatile("flushw" : : )
#define write_user_windows() __asm volatile("flushw" : : )
-void lwp_trampoline(void);
struct pcb;
void snapshot(struct pcb *);
struct frame *getfp(void);
Index: src/sys/arch/sparc64/sparc64/locore.s
diff -u src/sys/arch/sparc64/sparc64/locore.s:1.286 src/sys/arch/sparc64/sparc64/locore.s:1.286.2.1
--- src/sys/arch/sparc64/sparc64/locore.s:1.286 Thu Oct 30 12:29:45 2008
+++ src/sys/arch/sparc64/sparc64/locore.s Fri Jun 5 18:28:34 2009
@@ -1,4 +1,4 @@
-/* $NetBSD: locore.s,v 1.286 2008/10/30 12:29:45 nakayama Exp $ */
+/* $NetBSD: locore.s,v 1.286.2.1 2009/06/05 18:28:34 snj Exp $ */
/*
* Copyright (c) 1996-2002 Eduardo Horvath
@@ -6814,6 +6814,16 @@
ba,a,pt %icc, return_from_trap
nop
+ /*
+ * Like lwp_trampoline, but for cpu_setfunc(), i.e. without newlwp
+ * arguement and will not call lwp_startup.
+ */
+ENTRY(setfunc_trampoline)
+ call %l0 ! re-use current frame
+ mov %l1, %o0
+ ba,a,pt %icc, return_from_trap
+ nop
+
/*
* {fu,su}{,i}{byte,word}
*/
Index: src/sys/arch/sparc64/sparc64/vm_machdep.c
diff -u src/sys/arch/sparc64/sparc64/vm_machdep.c:1.84.4.1 src/sys/arch/sparc64/sparc64/vm_machdep.c:1.84.4.2
--- src/sys/arch/sparc64/sparc64/vm_machdep.c:1.84.4.1 Tue May 26 19:19:53 2009
+++ src/sys/arch/sparc64/sparc64/vm_machdep.c Fri Jun 5 18:28:34 2009
@@ -1,4 +1,4 @@
-/* $NetBSD: vm_machdep.c,v 1.84.4.1 2009/05/26 19:19:53 snj Exp $ */
+/* $NetBSD: vm_machdep.c,v 1.84.4.2 2009/06/05 18:28:34 snj Exp $ */
/*
* Copyright (c) 1996-2002 Eduardo Horvath. All rights reserved.
@@ -50,7 +50,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vm_machdep.c,v 1.84.4.1 2009/05/26 19:19:53 snj Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vm_machdep.c,v 1.84.4.2 2009/06/05 18:28:34 snj Exp $");
#include "opt_multiprocessor.h"
#include "opt_coredump.h"
@@ -162,6 +162,7 @@
char cpu_forkname[] = "cpu_lwp_fork()";
#endif
+void setfunc_trampoline(void);
inline void
cpu_setfunc(struct lwp *l, void (*func)(void *), void *arg)
{
@@ -171,9 +172,8 @@
rp = (struct rwindow *)((u_long)npcb + TOPFRAMEOFF);
rp->rw_local[0] = (long)func; /* Function to call */
rp->rw_local[1] = (long)arg; /* and its argument */
- rp->rw_local[2] = (long)l; /* new lwp */
- npcb->pcb_pc = (long)lwp_trampoline - 8;
+ npcb->pcb_pc = (long)setfunc_trampoline - 8;
npcb->pcb_sp = (long)rp - STACK_OFFSET;
}
@@ -195,6 +195,7 @@
* in both the stack and stacksize args), set up the user stack pointer
* accordingly.
*/
+void lwp_trampoline(void);
void
cpu_lwp_fork(l1, l2, stack, stacksize, func, arg)
register struct lwp *l1, *l2;
@@ -284,7 +285,12 @@
rp = (struct rwindow *)((u_long)npcb + TOPFRAMEOFF);
*rp = *(struct rwindow *)((u_long)opcb + TOPFRAMEOFF);
- cpu_setfunc(l2, func, arg);
+ rp->rw_local[0] = (long)func; /* Function to call */
+ rp->rw_local[1] = (long)arg; /* and its argument */
+ rp->rw_local[2] = (long)l2; /* new lwp */
+
+ npcb->pcb_pc = (long)lwp_trampoline - 8;
+ npcb->pcb_sp = (long)rp - STACK_OFFSET;
}
static inline void