Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev - Increase the default number of buffers, and scale ...
details: https://anonhg.NetBSD.org/src/rev/b092ab24ed7c
branches: trunk
changeset: 1004982:b092ab24ed7c
user: ad <ad%NetBSD.org@localhost>
date: Sat Nov 23 17:32:10 2019 +0000
description:
- Increase the default number of buffers, and scale it by ncpu.
- Stop tracing when the device is closed.
diffstat:
sys/dev/lockstat.c | 20 +++++++++++++-------
1 files changed, 13 insertions(+), 7 deletions(-)
diffs (60 lines):
diff -r c5dc8c3ffb1e -r b092ab24ed7c sys/dev/lockstat.c
--- a/sys/dev/lockstat.c Sat Nov 23 17:13:46 2019 +0000
+++ b/sys/dev/lockstat.c Sat Nov 23 17:32:10 2019 +0000
@@ -1,7 +1,7 @@
-/* $NetBSD: lockstat.c,v 1.25 2017/06/01 02:45:09 chs Exp $ */
+/* $NetBSD: lockstat.c,v 1.26 2019/11/23 17:32:10 ad Exp $ */
/*-
- * Copyright (c) 2006, 2007 The NetBSD Foundation, Inc.
+ * Copyright (c) 2006, 2007, 2019 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
@@ -37,10 +37,11 @@
* Only one thread can hold the device at a time, providing a global lock.
*
* XXX Timings for contention on sleep locks are currently incorrect.
+ * XXX Convert this to use timecounters!
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: lockstat.c,v 1.25 2017/06/01 02:45:09 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: lockstat.c,v 1.26 2019/11/23 17:32:10 ad Exp $");
#include <sys/types.h>
#include <sys/param.h>
@@ -71,7 +72,7 @@
#endif
#define LOCKSTAT_MINBUFS 1000
-#define LOCKSTAT_DEFBUFS 10000
+#define LOCKSTAT_DEFBUFS 20000
#define LOCKSTAT_MAXBUFS 1000000
#define LOCKSTAT_HASH_SIZE 128
@@ -453,6 +454,10 @@
{
lockstat_lwp = NULL;
+ if (lockstat_dev_enabled) {
+ lockstat_stop(NULL);
+ lockstat_free();
+ }
__cpu_simple_unlock(&lockstat_lock);
return 0;
}
@@ -490,9 +495,10 @@
/*
* Sanitize the arguments passed in and set up filtering.
*/
- if (le->le_nbufs == 0)
- le->le_nbufs = LOCKSTAT_DEFBUFS;
- else if (le->le_nbufs > LOCKSTAT_MAXBUFS ||
+ if (le->le_nbufs == 0) {
+ le->le_nbufs = MIN(LOCKSTAT_DEFBUFS * ncpu,
+ LOCKSTAT_MAXBUFS);
+ } else if (le->le_nbufs > LOCKSTAT_MAXBUFS ||
le->le_nbufs < LOCKSTAT_MINBUFS) {
error = EINVAL;
break;
Home |
Main Index |
Thread Index |
Old Index