From c2573f692dfa390d9c16c08b8105aa4c65555b26 Mon Sep 17 00:00:00 2001 From: davidxu Date: Fri, 14 Mar 2003 03:52:16 +0000 Subject: Export current time when returning from never blocked syscall. --- sys/kern/kern_kse.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'sys/kern/kern_kse.c') diff --git a/sys/kern/kern_kse.c b/sys/kern/kern_kse.c index 5a5a96f..81b0ed5 100644 --- a/sys/kern/kern_kse.c +++ b/sys/kern/kern_kse.c @@ -1603,11 +1603,18 @@ thread_userret(struct thread *td, struct trapframe *frame) mtx_lock_spin(&sched_lock); td->td_flags &= ~TDF_CAN_UNBIND; mtx_unlock_spin(&sched_lock); + ku = td->td_upcall; if ((p->p_flag & PS_NEEDSIGCHK) == 0 && (kg->kg_completed == NULL) && - (td->td_upcall->ku_flags & KUF_DOUPCALL) == 0) { + (ku->ku_flags & KUF_DOUPCALL) == 0) { thread_update_usr_ticks(td, 0); + nanotime(&ts); + error = copyout(&ts, + (caddr_t)&ku->ku_mailbox->km_timeofday, + sizeof(ts)); td->td_mailbox = 0; + if (error) + goto out; return (0); } error = thread_export_context(td); -- cgit v1.1