summaryrefslogtreecommitdiffstats
path: root/lib/libkse
diff options
context:
space:
mode:
authormarcel <marcel@FreeBSD.org>2003-12-07 20:47:33 +0000
committermarcel <marcel@FreeBSD.org>2003-12-07 20:47:33 +0000
commit4b6eafd82fbafd73173a2b8ae6f21e80991de13c (patch)
tree7aa3fc85bba2ec14ba56723694cb68dc2c17e301 /lib/libkse
parent239117c33ff76d4b8885237984b4345bdf0d9c9d (diff)
downloadFreeBSD-src-4b6eafd82fbafd73173a2b8ae6f21e80991de13c.zip
FreeBSD-src-4b6eafd82fbafd73173a2b8ae6f21e80991de13c.tar.gz
Simplify the contexts created by the kernel and remove the related
flags. We now create asynchronous contexts or syscall contexts only. Syscall contexts differ from the minimal ABI dictated contexts by having the scratch registers saved and restored because that's where we keep the syscall arguments and syscall return values. Since this change affects KSE, have it use kse_switchin(2) for the "new" syscall context.
Diffstat (limited to 'lib/libkse')
-rw-r--r--lib/libkse/arch/ia64/include/pthread_md.h6
1 files changed, 6 insertions, 0 deletions
diff --git a/lib/libkse/arch/ia64/include/pthread_md.h b/lib/libkse/arch/ia64/include/pthread_md.h
index 6598f3d..a72c953 100644
--- a/lib/libkse/arch/ia64/include/pthread_md.h
+++ b/lib/libkse/arch/ia64/include/pthread_md.h
@@ -232,6 +232,12 @@ _thread_switch(struct kcb *kcb, struct tcb *tcb, int setmbox)
mc->mc_special.isr = (intptr_t)&tcb->tcb_tmbx;
}
_ia64_break_setcontext(mc);
+ } else if (mc->mc_flags & _MC_FLAGS_SYSCALL_CONTEXT) {
+ if (setmbox)
+ kse_switchin(mc, (long)&tcb->tcb_tmbx,
+ (long *)&kcb->kcb_kmbx.km_curthread);
+ else
+ kse_switchin(mc, 0L, NULL);
} else {
if (setmbox)
_ia64_restore_context(mc, (intptr_t)&tcb->tcb_tmbx,
OpenPOWER on IntegriCloud