diff options
| author | 1996-03-19 21:09:06 +0000 | |
|---|---|---|
| committer | 1996-03-19 21:09:06 +0000 | |
| commit | f2d5a2e3b23957d1439f5602b921c081c44a11f3 (patch) | |
| tree | f62a2552be33640db192b7b84f501b8d038bb937 /sys/kern/kern_thread.c | |
| parent | Missed from last import. (diff) | |
| download | wireguard-openbsd-f2d5a2e3b23957d1439f5602b921c081c44a11f3.tar.xz wireguard-openbsd-f2d5a2e3b23957d1439f5602b921c081c44a11f3.zip | |
Merging w/ NetBSD 021796.
speaker upgraded to the current.
some changes to the VM stuff (ie kern_thread.c added and so).
Diffstat (limited to 'sys/kern/kern_thread.c')
| -rw-r--r-- | sys/kern/kern_thread.c | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/sys/kern/kern_thread.c b/sys/kern/kern_thread.c new file mode 100644 index 00000000000..5aa71b9e8cc --- /dev/null +++ b/sys/kern/kern_thread.c @@ -0,0 +1,83 @@ +/* $OpenBSD: kern_thread.c,v 1.1 1996/03/19 21:10:40 mickey Exp $ */ + +/* + * Copyright (c) 1987, 1990 Carnegie-Mellon University. + * All rights reserved. + * + * Permission to use, copy, modify and distribute this software and + * its documentation is hereby granted, provided that both the copyright + * notice and this permission notice appear in all copies of the + * software, derivative works or modified versions, and any portions + * thereof, and that both notices appear in supporting documentation. + * + * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" + * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND + * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. + * + * Carnegie Mellon requests users of this software to return to + * + * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU + * School of Computer Science + * Carnegie Mellon University + * Pittsburgh PA 15213-3890 + * + * any improvements or extensions that they make and grant Carnegie the + * rights to redistribute these changes. + */ + +#include <sys/param.h> +#include <sys/systm.h> +#include <sys/proc.h> +#include <vm/vm_param.h> +#include <vm/lock.h> + +/* + * The rest of these routines fake thread handling + */ + +void +assert_wait(event, interruptible) + event_t event; + boolean_t interruptible; +{ +#ifdef lint + interruptible++; +#endif + current_thread() = (thread_t)event; /* XXX */ +} + +void +thread_block() +{ + int s = splhigh(); + + if (current_thread()) + tsleep(current_thread(), PVM, "thrd_block", 0); + splx(s); +} + +void +thread_sleep(event, lock, interruptible) + event_t event; + simple_lock_t lock; + boolean_t interruptible; +{ + int s = splhigh(); + + assert_wait (event, interruptible); + simple_unlock(lock); + if (current_thread()) + tsleep(event, PVM, "thrd_sleep", 0); + splx(s); +} + +void +thread_wakeup(event) + event_t event; +{ + int s = splhigh(); + + wakeup(event); + splx(s); +} + |
