Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys lwp_setlock(): return pointer to the kmutex_t that we re...
details: https://anonhg.NetBSD.org/src/rev/a0eb268a41e6
branches: trunk
changeset: 465414:a0eb268a41e6
user: ad <ad%NetBSD.org@localhost>
date: Thu Nov 21 19:47:21 2019 +0000
description:
lwp_setlock(): return pointer to the kmutex_t that we replaced
diffstat:
sys/kern/kern_lwp.c | 14 ++++++++------
sys/sys/lwp.h | 4 ++--
2 files changed, 10 insertions(+), 8 deletions(-)
diffs (69 lines):
diff -r 7b136dfb0c30 -r a0eb268a41e6 sys/kern/kern_lwp.c
--- a/sys/kern/kern_lwp.c Thu Nov 21 19:27:54 2019 +0000
+++ b/sys/kern/kern_lwp.c Thu Nov 21 19:47:21 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: kern_lwp.c,v 1.210 2019/11/21 18:22:05 ad Exp $ */
+/* $NetBSD: kern_lwp.c,v 1.211 2019/11/21 19:47:21 ad Exp $ */
/*-
* Copyright (c) 2001, 2006, 2007, 2008, 2009, 2019 The NetBSD Foundation, Inc.
@@ -211,7 +211,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_lwp.c,v 1.210 2019/11/21 18:22:05 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_lwp.c,v 1.211 2019/11/21 19:47:21 ad Exp $");
#include "opt_ddb.h"
#include "opt_lockdebug.h"
@@ -1475,14 +1475,16 @@
/*
* Lend a new mutex to an LWP. The old mutex must be held.
*/
-void
+kmutex_t *
lwp_setlock(struct lwp *l, kmutex_t *mtx)
{
+ kmutex_t *oldmtx = l->l_mutex;
- KASSERT(mutex_owned(l->l_mutex));
+ KASSERT(mutex_owned(oldmtx));
membar_exit();
l->l_mutex = mtx;
+ return oldmtx;
}
/*
@@ -1517,11 +1519,11 @@
}
void
-lwp_unsleep(lwp_t *l, bool cleanup)
+lwp_unsleep(lwp_t *l, bool unlock)
{
KASSERT(mutex_owned(l->l_mutex));
- (*l->l_syncobj->sobj_unsleep)(l, cleanup);
+ (*l->l_syncobj->sobj_unsleep)(l, unlock);
}
/*
diff -r 7b136dfb0c30 -r a0eb268a41e6 sys/sys/lwp.h
--- a/sys/sys/lwp.h Thu Nov 21 19:27:54 2019 +0000
+++ b/sys/sys/lwp.h Thu Nov 21 19:47:21 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lwp.h,v 1.188 2019/11/14 16:23:53 maxv Exp $ */
+/* $NetBSD: lwp.h,v 1.189 2019/11/21 19:47:21 ad Exp $ */
/*
* Copyright (c) 2001, 2006, 2007, 2008, 2009, 2010
@@ -326,7 +326,7 @@
void startlwp(void *);
int lwp_locked(lwp_t *, kmutex_t *);
-void lwp_setlock(lwp_t *, kmutex_t *);
+kmutex_t *lwp_setlock(lwp_t *, kmutex_t *);
void lwp_unlock_to(lwp_t *, kmutex_t *);
int lwp_trylock(lwp_t *);
void lwp_addref(lwp_t *);
Home |
Main Index |
Thread Index |
Old Index