summaryrefslogtreecommitdiff
path: root/sys/arch/mips64
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/mips64')
-rw-r--r--sys/arch/mips64/include/cpu.h28
-rw-r--r--sys/arch/mips64/include/proc.h3
-rw-r--r--sys/arch/mips64/mips64/exception.S16
-rw-r--r--sys/arch/mips64/mips64/interrupt.c30
-rw-r--r--sys/arch/mips64/mips64/trap.c54
5 files changed, 64 insertions, 67 deletions
diff --git a/sys/arch/mips64/include/cpu.h b/sys/arch/mips64/include/cpu.h
index 73d559c8589..f16edec4b76 100644
--- a/sys/arch/mips64/include/cpu.h
+++ b/sys/arch/mips64/include/cpu.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.h,v 1.32 2009/06/02 17:55:37 miod Exp $ */
+/* $OpenBSD: cpu.h,v 1.33 2009/06/10 18:05:30 miod Exp $ */
/*-
* Copyright (c) 1992, 1993
@@ -358,10 +358,13 @@ extern vaddr_t uncached_base;
#include <sys/sched.h>
struct cpu_info {
- struct schedstate_percpu ci_schedstate;
+ struct proc *ci_curproc;
- struct proc *ci_curproc;
- u_int32_t ci_randseed;
+ struct schedstate_percpu
+ ci_schedstate;
+ int ci_want_resched; /* need_resched() invoked */
+
+ u_int32_t ci_randseed; /* per cpu random seed */
};
extern struct cpu_info cpu_info_primary;
@@ -401,25 +404,28 @@ extern int int_nest_cntr;
* Preempt the current process if in interrupt from user mode,
* or after the current trap/syscall if in system mode.
*/
-#define need_resched(info) { want_resched = 1; aston(); }
-#define clear_resched(ci) want_resched = 0
+#define need_resched(ci) \
+ do { \
+ (ci)->ci_want_resched = 1; \
+ if ((ci)->ci_curproc != NULL) \
+ aston((ci)->ci_curproc); \
+ } while(0)
+#define clear_resched(ci) (ci)->ci_want_resched = 0
/*
* Give a profiling tick to the current process when the user profiling
* buffer pages are invalid. On the PICA, request an ast to send us
* through trap, marking the proc as needing a profiling tick.
*/
-#define need_proftick(p) aston()
+#define need_proftick(p) aston(p)
/*
* Notify the current process (p) that it has a signal pending,
* process as soon as possible.
*/
-#define signotify(p) aston()
-
-#define aston() (astpending = 1)
+#define signotify(p) aston(p)
-extern int want_resched; /* resched() was called */
+#define aston(p) p->p_md.md_astpending = 1
#endif /* !_LOCORE */
#endif /* _KERNEL */
diff --git a/sys/arch/mips64/include/proc.h b/sys/arch/mips64/include/proc.h
index eb7c88ab1ad..bbdd8f4a1af 100644
--- a/sys/arch/mips64/include/proc.h
+++ b/sys/arch/mips64/include/proc.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: proc.h,v 1.2 2005/08/07 07:29:44 miod Exp $ */
+/* $OpenBSD: proc.h,v 1.3 2009/06/10 18:05:30 miod Exp $ */
/*
* Copyright (c) 1992, 1993
@@ -42,6 +42,7 @@
*/
struct mdproc {
struct trap_frame *md_regs; /* registers on current frame */
+ volatile int md_astpending; /* AST pending for this process */
int md_flags; /* machine-dependent flags */
long md_ss_addr; /* single step address for ptrace */
int md_ss_instr; /* single step instruction for ptrace */
diff --git a/sys/arch/mips64/mips64/exception.S b/sys/arch/mips64/mips64/exception.S
index df4dafdbcd6..9f59cef068b 100644
--- a/sys/arch/mips64/mips64/exception.S
+++ b/sys/arch/mips64/mips64/exception.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: exception.S,v 1.19 2009/05/27 18:58:15 miod Exp $ */
+/* $OpenBSD: exception.S,v 1.20 2009/06/10 18:05:31 miod Exp $ */
/*
* Copyright (c) 2002-2003 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -47,6 +47,8 @@
#include "assym.h"
+#define curproc (cpu_info_primary + CI_CURPROC)
+
.set mips3
.data
@@ -246,11 +248,12 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
ITLBNOPFIX
0:
- lw v0, astpending # any pending interrupts?
+ PTR_L t0, curproc
+ lw v0, P_ASTPENDING(t0) # any pending AST?
beq v0, zero, 4f
nop
- PTR_L t0, curprocpaddr
+ PTR_L t0, P_ADDR(t0) # curprocpaddr
SAVE_CPU_SREG(t0, 0)
#ifdef PERFCNTRS
@@ -431,11 +434,12 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra)
PTR_S a3, CF_RA_OFFS(sp) # for debugging
0:
- lw v0, astpending
- beqz v0, 4f
+ PTR_L t0, curproc
+ lw v0, P_ASTPENDING(t0) # any pending AST?
+ beq v0, zero, 4f
nop
- PTR_L t0, curprocpaddr
+ PTR_L t0, P_ADDR(t0) # curprocpaddr
SAVE_CPU_SREG(t0, 0)
jal ast
diff --git a/sys/arch/mips64/mips64/interrupt.c b/sys/arch/mips64/mips64/interrupt.c
index e431f2f9a6f..16e5c79ce89 100644
--- a/sys/arch/mips64/mips64/interrupt.c
+++ b/sys/arch/mips64/mips64/interrupt.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: interrupt.c,v 1.39 2009/05/27 18:58:15 miod Exp $ */
+/* $OpenBSD: interrupt.c,v 1.40 2009/06/10 18:05:31 miod Exp $ */
/*
* Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -59,7 +59,7 @@ static struct evcount soft_count;
static int soft_irq = 0;
volatile intrmask_t cpl;
-volatile intrmask_t ipending, astpending;
+volatile intrmask_t ipending;
intrmask_t imask[NIPLS];
@@ -121,7 +121,6 @@ int_f *pending_hand = &dummy_do_pending_int;
*/
void interrupt(struct trap_frame *);
-void ast(void);
/*
* Handle an interrupt. Both kernel and user mode is handled here.
@@ -232,31 +231,6 @@ set_intr(int pri, intrmask_t mask,
idle_mask |= mask | SOFT_INT_MASK;
}
-/*
- * This is called from MipsUserIntr() if astpending is set.
- */
-void
-ast()
-{
- struct proc *p = curproc;
- int sig;
-
- uvmexp.softs++;
-
- astpending = 0;
- if (p->p_flag & P_OWEUPC) {
- ADDUPROF(p);
- }
- if (want_resched)
- preempt(NULL);
-
- /* inline userret(p) */
-
- while ((sig = CURSIG(p)) != 0) /* take pending signals */
- postsig(sig);
- p->p_cpu->ci_schedstate.spc_curpriority = p->p_priority = p->p_usrpri;
-}
-
struct intrhand *intrhand[INTMASKSIZE];
void
diff --git a/sys/arch/mips64/mips64/trap.c b/sys/arch/mips64/mips64/trap.c
index b7b0947fbbb..3cb3ce5b097 100644
--- a/sys/arch/mips64/mips64/trap.c
+++ b/sys/arch/mips64/mips64/trap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: trap.c,v 1.42 2009/05/22 20:37:53 miod Exp $ */
+/* $OpenBSD: trap.c,v 1.43 2009/06/10 18:05:31 miod Exp $ */
/* tracked to 1.23 */
/*
@@ -92,10 +92,9 @@
#define USERMODE(ps) (((ps) & SR_KSU_MASK) == SR_KSU_USER)
-int want_resched; /* resched() was called */
struct proc *machFPCurProcPtr; /* pointer to last proc to use FP */
-char *trap_type[] = {
+const char *trap_type[] = {
"external interrupt",
"TLB modification",
"TLB miss (load or instr. fetch)",
@@ -127,33 +126,30 @@ char *trap_type[] = {
"reserved 28",
"reserved 29",
"reserved 30",
- "virtual coherency data",
+ "virtual coherency data"
};
#if defined(DDB) || defined(DEBUG)
-extern register_t *tlbtrcptr;
struct trapdebug trapdebug[TRAPSIZE], *trp = trapdebug;
-void stacktrace(struct trap_frame *);
-void logstacktrace(struct trap_frame *);
-int kdbpeek(void *);
-/* extern functions printed by name in stack backtraces */
-extern void idle(void);
+void stacktrace(struct trap_frame *);
+int kdbpeek(void *);
#endif /* DDB || DEBUG */
#if defined(DDB)
-int kdb_trap(int, db_regs_t *);
+extern int kdb_trap(int, db_regs_t *);
#endif
extern void MipsSwitchFPState(struct proc *, struct trap_frame *);
extern void MipsSwitchFPState16(struct proc *, struct trap_frame *);
extern void MipsFPTrap(u_int, u_int, u_int, union sigval);
-void trap(struct trap_frame *);
+void ast(void);
+void trap(struct trap_frame *);
#ifdef PTRACE
-int cpu_singlestep(struct proc *);
+int cpu_singlestep(struct proc *);
#endif
-u_long MipsEmulateBranch(struct trap_frame *, long, int, u_int);
+u_long MipsEmulateBranch(struct trap_frame *, long, int, u_int);
static __inline__ void
userret(struct proc *p)
@@ -168,6 +164,29 @@ userret(struct proc *p)
}
/*
+ * Handle an AST for the current process.
+ */
+void
+ast()
+{
+ struct cpu_info *ci = curcpu();
+ struct proc *p = ci->ci_curproc;
+
+ uvmexp.softs++;
+
+if (p->p_md.md_astpending == 0)
+panic("unexpected ast p %p astpending %p\n", p, &p->p_md.md_astpending);
+ p->p_md.md_astpending = 0;
+ if (p->p_flag & P_OWEUPC) {
+ ADDUPROF(p);
+ }
+ if (ci->ci_want_resched)
+ preempt(NULL);
+
+ userret(p);
+}
+
+/*
* Handle an exception.
* In the case of a kernel trap, we return the pc where to resume if
* pcb_onfault is set, otherwise, return old pc.
@@ -1117,13 +1136,6 @@ stacktrace(regs)
}
void
-logstacktrace(regs)
- struct trap_frame *regs;
-{
- stacktrace_subr(regs, addlog);
-}
-
-void
stacktrace_subr(regs, printfn)
struct trap_frame *regs;
int (*printfn)(const char*, ...);