summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcheloha <cheloha@cvs.openbsd.org>2020-01-24 15:58:34 +0000
committercheloha <cheloha@cvs.openbsd.org>2020-01-24 15:58:34 +0000
commit7fecfc011e42d21ce3f65b4f5855d9fc88160b16 (patch)
treefcb35f28deb9ae28eec69de3a9b48ac1ff5606d4
parent02bf819f950d91d048cbee120208a20e257c6474 (diff)
*sleep_nsec(9): log process name and pid when nsecs == 0
We included DIAGNOSTIC in *sleep_nsec(9) when they were first committed to help us sniff out divison-to-zero bugs when converting *sleep(9) callers to the new interfaces. Recently we exposed the new interface to userland callers. This has yielded some warnings. This diff adds a process name and pid to the warnings to help determine the source of the zero-length sleeps. ok mpi@
-rw-r--r--sys/kern/kern_synch.c20
1 files changed, 13 insertions, 7 deletions
diff --git a/sys/kern/kern_synch.c b/sys/kern/kern_synch.c
index 3ca58be881e..f23fdfffcda 100644
--- a/sys/kern/kern_synch.c
+++ b/sys/kern/kern_synch.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: kern_synch.c,v 1.160 2020/01/21 16:16:23 mpi Exp $ */
+/* $OpenBSD: kern_synch.c,v 1.161 2020/01/24 15:58:33 cheloha Exp $ */
/* $NetBSD: kern_synch.c,v 1.37 1996/04/22 01:38:37 christos Exp $ */
/*
@@ -164,8 +164,10 @@ tsleep_nsec(const volatile void *ident, int priority, const char *wmesg,
return tsleep(ident, priority, wmesg, 0);
#ifdef DIAGNOSTIC
if (nsecs == 0) {
- log(LOG_WARNING, "%s: %s: trying to sleep zero nanoseconds\n",
- __func__, wmesg);
+ log(LOG_WARNING,
+ "%s: %s[%d]: %s: trying to sleep zero nanoseconds\n",
+ __func__, curproc->p_p->ps_comm, curproc->p_p->ps_pid,
+ wmesg);
}
#endif
/*
@@ -288,8 +290,10 @@ msleep_nsec(const volatile void *ident, struct mutex *mtx, int priority,
return msleep(ident, mtx, priority, wmesg, 0);
#ifdef DIAGNOSTIC
if (nsecs == 0) {
- log(LOG_WARNING, "%s: %s: trying to sleep zero nanoseconds\n",
- __func__, wmesg);
+ log(LOG_WARNING,
+ "%s: %s[%d]: %s: trying to sleep zero nanoseconds\n",
+ __func__, curproc->p_p->ps_comm, curproc->p_p->ps_pid,
+ wmesg);
}
#endif
nsecs = MIN(nsecs, UINT64_MAX - tick_nsec);
@@ -338,8 +342,10 @@ rwsleep_nsec(const volatile void *ident, struct rwlock *rwl, int priority,
return rwsleep(ident, rwl, priority, wmesg, 0);
#ifdef DIAGNOSTIC
if (nsecs == 0) {
- log(LOG_WARNING, "%s: %s: trying to sleep zero nanoseconds\n",
- __func__, wmesg);
+ log(LOG_WARNING,
+ "%s: %s[%d]: %s: trying to sleep zero nanoseconds\n",
+ __func__, curproc->p_p->ps_comm, curproc->p_p->ps_pid,
+ wmesg);
}
#endif
nsecs = MIN(nsecs, UINT64_MAX - tick_nsec);