svn commit: r355632 - in head/sys: kern sys
Mateusz Guzik
mjg at FreeBSD.org
Wed Dec 11 23:09:13 UTC 2019
Author: mjg
Date: Wed Dec 11 23:09:12 2019
New Revision: 355632
URL: https://svnweb.freebsd.org/changeset/base/355632
Log:
fd: static-ize and devolatile openfiles
Almost all access is using atomics. The only read is sysctl which should use
a whole-int-at-a-time friendly read internally.
Modified:
head/sys/kern/kern_descrip.c
head/sys/sys/file.h
Modified: head/sys/kern/kern_descrip.c
==============================================================================
--- head/sys/kern/kern_descrip.c Wed Dec 11 22:51:02 2019 (r355631)
+++ head/sys/kern/kern_descrip.c Wed Dec 11 23:09:12 2019 (r355632)
@@ -174,7 +174,7 @@ struct filedesc0 {
/*
* Descriptor management.
*/
-volatile int __exclusive_cache_line openfiles; /* actual number of open files */
+static int __exclusive_cache_line openfiles; /* actual number of open files */
struct mtx sigio_lock; /* mtx to protect pointers to sigio */
void __read_mostly (*mq_fdclose)(struct thread *td, int fd, struct file *fp);
@@ -4048,7 +4048,7 @@ SYSCTL_INT(_kern, KERN_MAXFILES, maxfiles, CTLFLAG_RW,
&maxfiles, 0, "Maximum number of files");
SYSCTL_INT(_kern, OID_AUTO, openfiles, CTLFLAG_RD,
- __DEVOLATILE(int *, &openfiles), 0, "System-wide number of open files");
+ &openfiles, 0, "System-wide number of open files");
/* ARGSUSED*/
static void
Modified: head/sys/sys/file.h
==============================================================================
--- head/sys/sys/file.h Wed Dec 11 22:51:02 2019 (r355631)
+++ head/sys/sys/file.h Wed Dec 11 23:09:12 2019 (r355632)
@@ -241,7 +241,6 @@ extern struct fileops badfileops;
extern struct fileops socketops;
extern int maxfiles; /* kernel limit on number of open files */
extern int maxfilesperproc; /* per process limit on number of open files */
-extern volatile int openfiles; /* actual number of open files */
int fget(struct thread *td, int fd, cap_rights_t *rightsp, struct file **fpp);
int fget_mmap(struct thread *td, int fd, cap_rights_t *rightsp,
More information about the svn-src-all
mailing list