diff options
author | Paul Irofti <pirofti@cvs.openbsd.org> | 2013-04-10 13:11:25 +0000 |
---|---|---|
committer | Paul Irofti <pirofti@cvs.openbsd.org> | 2013-04-10 13:11:25 +0000 |
commit | 0c158f2277bfba386edcd7e799892e4fd2bb36ab (patch) | |
tree | 4e13d094623c4822013a0c5bc40559107fb8675e /sys/compat/linux/linux_futex.c | |
parent | ba306cd6345b4a1b1901745ccec9a63764c59b6d (diff) |
futex: Sprinkle a few debug printfs that helped me in the past.
Diffstat (limited to 'sys/compat/linux/linux_futex.c')
-rw-r--r-- | sys/compat/linux/linux_futex.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/sys/compat/linux/linux_futex.c b/sys/compat/linux/linux_futex.c index 8442c6b63ef..0ee34735b3e 100644 --- a/sys/compat/linux/linux_futex.c +++ b/sys/compat/linux/linux_futex.c @@ -1,4 +1,4 @@ -/* $OpenBSD: linux_futex.c,v 1.12 2013/04/10 12:58:52 pirofti Exp $ */ +/* $OpenBSD: linux_futex.c,v 1.13 2013/04/10 13:11:24 pirofti Exp $ */ /* $NetBSD: linux_futex.c,v 1.26 2010/07/07 01:30:35 chs Exp $ */ /*- @@ -172,6 +172,7 @@ linux_do_futex(struct proc *p, const struct linux_sys_futex_args *uap, switch (SCARG(uap, op) & ~LINUX_FUTEX_PRIVATE_FLAG) { case LINUX_FUTEX_WAIT: + DPRINTF(("FUTEX_WAIT\n")); mtx_enter(&futex_lock); if ((error = copyin(SCARG(uap, uaddr), &uaddr_val, sizeof(uaddr_val))) != 0) { @@ -221,12 +222,14 @@ linux_do_futex(struct proc *p, const struct linux_sys_futex_args *uap, mtx_leave(&futex_lock); return EAGAIN; } + DPRINTF(("FUTEX_WAIT: get wp %p\n", wp)); f = futex_get(SCARG(uap, uaddr)); ret = futex_sleep(&f, p, timeout_hz, wp); futex_put(f); mtx_leave(&futex_lock); + DPRINTF(("FUTEX_WAIT: put wp %p\n", wp)); pool_put(&futex_wp_pool, wp); DPRINTF(("FUTEX_WAIT %d: Woke up from uaddr %8.8X with " @@ -275,6 +278,7 @@ linux_do_futex(struct proc *p, const struct linux_sys_futex_args *uap, case LINUX_FUTEX_CMP_REQUEUE: + DPRINTF(("FUTEX_CMP_REQUEUE\n")); if (args_val < 0) return EINVAL; @@ -436,12 +440,14 @@ futex_get(void *uaddr) /* Not found, create it */ newf = pool_get(&futex_pool, PR_WAITOK|PR_ZERO); + DPRINTF(("futex_get: get %p\n", newf)); mtx_enter(&futex_lock); /* Did someone else create it in the meantime? */ LIST_FOREACH(f, &futex_list, f_list) { if (f->f_uaddr == uaddr) { f->f_refcount++; + DPRINTF(("futex_get: put %p (found %p)\n", newf, f)); pool_put(&futex_pool, newf); return f; } @@ -473,6 +479,7 @@ futex_ref(struct futex *f) void futex_put(struct futex *f) { + DPRINTF(("futex_put: put %p ref %d\n", f, f->f_refcount)); MUTEX_ASSERT_LOCKED(&futex_lock); KASSERT(f->f_refcount > 0); f->f_refcount--; |