diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2005-11-28 22:21:17 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2005-11-28 22:21:17 +0000 |
commit | 9407a589e754c164aa72b047d01fb5e153c17425 (patch) | |
tree | d3da1224369b1d10190c82a3eb85dea65d1c4788 /sys/arch/m88k/include/cpu.h | |
parent | 9ae0cfd2137b39e09286f9be25b44548e121e4ad (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.h | 26 |
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. |