Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys Set a better default for MAXFILES on larger RAM machines...
details: https://anonhg.NetBSD.org/src/rev/6364ce8dc603
branches: trunk
changeset: 956958:6364ce8dc603
user: simonb <simonb%NetBSD.org@localhost>
date: Thu Nov 12 07:44:01 2020 +0000
description:
Set a better default for MAXFILES on larger RAM machines if not
otherwise specified the kernel config file. Arbitary numbers are
20,000 files for 16GB RAM or more and 10,000 files for 1GB RAM or
more.
TODO: Adjust this and other values totally dynamically.
diffstat:
sys/conf/param.c | 8 ++------
sys/kern/init_main.c | 21 ++++++++++++++++++---
sys/sys/param.h | 14 +++++++++-----
3 files changed, 29 insertions(+), 14 deletions(-)
diffs (110 lines):
diff -r 4606e16ee072 -r 6364ce8dc603 sys/conf/param.c
--- a/sys/conf/param.c Thu Nov 12 02:15:56 2020 +0000
+++ b/sys/conf/param.c Thu Nov 12 07:44:01 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: param.c,v 1.68 2019/04/09 22:05:27 pgoyette Exp $ */
+/* $NetBSD: param.c,v 1.69 2020/11/12 07:44:01 simonb Exp $ */
/*
* Copyright (c) 1980, 1986, 1989 Regents of the University of California.
@@ -37,7 +37,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: param.c,v 1.68 2019/04/09 22:05:27 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: param.c,v 1.69 2020/11/12 07:44:01 simonb Exp $");
#ifdef _KERNEL_OPT
#include "opt_hz.h"
@@ -105,10 +105,6 @@
#define HZ 100
#endif
-#ifndef MAXFILES
-#define MAXFILES (3 * (NPROC + MAXUSERS) + 80)
-#endif
-
#ifndef MAXEXEC
#define MAXEXEC 16
#endif
diff -r 4606e16ee072 -r 6364ce8dc603 sys/kern/init_main.c
--- a/sys/kern/init_main.c Thu Nov 12 02:15:56 2020 +0000
+++ b/sys/kern/init_main.c Thu Nov 12 07:44:01 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: init_main.c,v 1.532 2020/11/04 01:30:19 chs Exp $ */
+/* $NetBSD: init_main.c,v 1.533 2020/11/12 07:44:01 simonb Exp $ */
/*-
* Copyright (c) 2008, 2009, 2019 The NetBSD Foundation, Inc.
@@ -97,7 +97,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: init_main.c,v 1.532 2020/11/04 01:30:19 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: init_main.c,v 1.533 2020/11/12 07:44:01 simonb Exp $");
#include "opt_cnmagic.h"
#include "opt_ddb.h"
@@ -485,7 +485,22 @@
10, VNODE_KMEM_MAXPCT) / VNODE_COST;
if (usevnodes > desiredvnodes)
desiredvnodes = usevnodes;
-#endif
+#endif /* NVNODE_IMPLICIT */
+#ifdef MAXFILES_IMPLICIT
+ /*
+ * If maximum number of files is not explicitly defined in
+ * kernel config, adjust the number so that it is somewhat
+ * more reasonable on machines with larger memory sizes.
+ * Arbitary numbers are 20,000 files for 16GB RAM or more
+ * and 10,000 files for 1GB RAM or more.
+ *
+ * XXXtodo: adjust this and other values totally dynamically
+ */
+ if (ctob((uint64_t)physmem) >= 16ULL * 1024 * 1024 * 1024)
+ maxfiles = MAX(maxfiles, 20000);
+ if (ctob((uint64_t)physmem) >= 1024 * 1024 * 1024)
+ maxfiles = MAX(maxfiles, 10000);
+#endif /* MAXFILES_IMPLICIT */
/* Initialize fstrans. */
fstrans_init();
diff -r 4606e16ee072 -r 6364ce8dc603 sys/sys/param.h
--- a/sys/sys/param.h Thu Nov 12 02:15:56 2020 +0000
+++ b/sys/sys/param.h Thu Nov 12 07:44:01 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: param.h,v 1.678 2020/11/01 18:51:03 pgoyette Exp $ */
+/* $NetBSD: param.h,v 1.679 2020/11/12 07:44:01 simonb Exp $ */
/*-
* Copyright (c) 1982, 1986, 1989, 1993
@@ -148,13 +148,17 @@
#include <sys/uio.h>
#include <uvm/uvm_param.h>
#ifndef NPROC
-#define NPROC (20 + 16 * MAXUSERS)
+#define NPROC (20 + 16 * MAXUSERS)
+#endif
+#ifndef MAXFILES
+#define MAXFILES (3 * (NPROC + MAXUSERS) + 80)
+#define MAXFILES_IMPLICIT
#endif
#ifndef NTEXT
-#define NTEXT (80 + NPROC / 8) /* actually the object cache */
+#define NTEXT (80 + NPROC / 8) /* actually the object cache */
#endif
#ifndef NVNODE
-#define NVNODE (NPROC + NTEXT + 100)
+#define NVNODE (NPROC + NTEXT + 100)
#define NVNODE_IMPLICIT
#endif
#ifndef VNODE_KMEM_MAXPCT
@@ -163,7 +167,7 @@
#ifndef BUFCACHE_VA_MAXPCT
#define BUFCACHE_VA_MAXPCT 20
#endif
-#define VNODE_COST 2048 /* assumed space in bytes */
+#define VNODE_COST 2048 /* assumed space in bytes */
#endif /* _KERNEL */
/* Signals. */
Home |
Main Index |
Thread Index |
Old Index