summaryrefslogtreecommitdiff
path: root/sys/arch/m88k/include/cpu.h
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2005-11-28 22:21:17 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2005-11-28 22:21:17 +0000
commit9407a589e754c164aa72b047d01fb5e153c17425 (patch)
treed3da1224369b1d10190c82a3eb85dea65d1c4788 /sys/arch/m88k/include/cpu.h
parent9ae0cfd2137b39e09286f9be25b44548e121e4ad (diff)
Switch to per-process AST flags and clean AST-related codepaths; speeds up
forks as a bonus. Tested on luna88k and mvme88k by aoyama@ martin@ and I.
Diffstat (limited to 'sys/arch/m88k/include/cpu.h')
-rw-r--r--sys/arch/m88k/include/cpu.h26
1 files changed, 16 insertions, 10 deletions
diff --git a/sys/arch/m88k/include/cpu.h b/sys/arch/m88k/include/cpu.h
index 948bb00fe56..fc3a85cfba1 100644
--- a/sys/arch/m88k/include/cpu.h
+++ b/sys/arch/m88k/include/cpu.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.h,v 1.7 2005/10/13 19:48:32 miod Exp $ */
+/* $OpenBSD: cpu.h,v 1.8 2005/11/28 22:21:15 miod Exp $ */
/*
* Copyright (c) 1996 Nivas Madhur
* Copyright (c) 1992, 1993
@@ -95,8 +95,8 @@ struct clockframe {
struct trapframe tf;
};
-#define CLKF_USERMODE(framep) ((((struct trapframe *)(framep))->tf_epsr & PSR_MODE) == 0)
-#define CLKF_PC(framep) (((struct trapframe *)(framep))->tf_sxip & XIP_ADDR)
+#define CLKF_USERMODE(framep) (((framep)->tf.tf_epsr & PSR_MODE) == 0)
+#define CLKF_PC(framep) ((framep)->tf.tf_sxip & XIP_ADDR)
#define CLKF_INTR(framep) (0) /* XXX temporary */
/*
@@ -108,33 +108,39 @@ struct clockframe {
#define SIR_CLOCK 2
#define setsoftint(x) (ssir |= (x))
-#define setsoftnet() (ssir |= SIR_NET)
-#define setsoftclock() (ssir |= SIR_CLOCK)
+#define setsoftnet() setsoftint(SIR_NET)
+#define setsoftclock() setsoftint(SIR_CLOCK)
-#define siroff(x) (ssir &= ~x)
+#define siroff(x) (ssir &= ~(x))
extern int ssir;
-extern int want_ast;
+
+#define aston(p) ((p)->p_md.md_astpending = 1)
/*
* Preempt the current process if in interrupt from user mode,
* or after the current trap/syscall if in system mode.
*/
extern int want_resched; /* resched() was called */
-#define need_resched(ci) (want_resched = 1, want_ast = 1)
+#define need_resched(ci) \
+do { \
+ want_resched = 1; \
+ if (curproc != NULL) \
+ aston(curproc); \
+} while (0)
/*
* Give a profiling tick to the current process when the user profiling
* buffer pages are invalid. On the sparc, request an ast to send us
* through trap(), marking the proc as needing a profiling tick.
*/
-#define need_proftick(p) ((p)->p_flag |= P_OWEUPC, want_ast = 1)
+#define need_proftick(p) ((p)->p_flag |= P_OWEUPC, aston(p))
/*
* Notify the current process (p) that it has a signal pending,
* process as soon as possible.
*/
-#define signotify(p) (want_ast = 1)
+#define signotify(p) aston(p)
/*
* switchframe - should be double word aligned.