Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/kern More preparation for modularizing the SYSVxxx optio...



details:   https://anonhg.NetBSD.org/src/rev/496801a14285
branches:  trunk
changeset: 338154:496801a14285
user:      pgoyette <pgoyette%NetBSD.org@localhost>
date:      Wed May 13 01:00:16 2015 +0000

description:
More preparation for modularizing the SYSVxxx options.  Here we
change the kern.ipc.sysvxxx sysctls into dynamic values, so each
sub-component of SYSVxxx can declare its own availability.

diffstat:

 sys/kern/init_sysctl.c |  49 +++++++++++++++++++++++--------------------------
 sys/kern/sysv_msg.c    |   8 ++++++--
 sys/kern/sysv_sem.c    |  10 ++++++++--
 sys/kern/sysv_shm.c    |   8 ++++++--
 4 files changed, 43 insertions(+), 32 deletions(-)

diffs (195 lines):

diff -r 01103623d19a -r 496801a14285 sys/kern/init_sysctl.c
--- a/sys/kern/init_sysctl.c    Tue May 12 23:16:47 2015 +0000
+++ b/sys/kern/init_sysctl.c    Wed May 13 01:00:16 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: init_sysctl.c,v 1.205 2015/04/22 16:42:24 pooka Exp $ */
+/*     $NetBSD: init_sysctl.c,v 1.206 2015/05/13 01:00:16 pgoyette Exp $ */
 
 /*-
  * Copyright (c) 2003, 2007, 2008, 2009 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: init_sysctl.c,v 1.205 2015/04/22 16:42:24 pooka Exp $");
+__KERNEL_RCSID(0, "$NetBSD: init_sysctl.c,v 1.206 2015/05/13 01:00:16 pgoyette Exp $");
 
 #include "opt_sysv.h"
 #include "opt_compat_netbsd.h"
@@ -75,6 +75,16 @@
 gid_t security_setidcore_group = 0;
 mode_t security_setidcore_mode = (S_IRUSR|S_IWUSR);
 
+/*
+ * Current status of SysV IPC capability.  Initially, these are
+ * 0 if the capability is not built-in to the kernel, but can
+ * be updated if the appropriate kernel module is (auto)loaded.
+ */
+
+int kern_has_sysvmsg = 0;
+int kern_has_sysvshm = 0;
+int kern_has_sysvsem = 0;
+
 static const u_int sysctl_lwpprflagmap[] = {
        LPR_DETACHED, L_DETACHED,
        0
@@ -276,38 +286,25 @@
                       NULL, 0, NULL, 0,
                       CTL_KERN, KERN_SYSVIPC, CTL_EOL);
        sysctl_createv(clog, 0, NULL, NULL,
-                      CTLFLAG_PERMANENT|CTLFLAG_IMMEDIATE,
+                      CTLFLAG_PERMANENT|CTLFLAG_READONLY,
                       CTLTYPE_INT, "sysvmsg",
                       SYSCTL_DESCR("System V style message support available"),
-                      NULL,
-#ifdef SYSVMSG
-                      1,
-#else /* SYSVMSG */
-                      0,
-#endif /* SYSVMSG */
-                      NULL, 0, CTL_KERN, KERN_SYSVIPC, KERN_SYSVIPC_MSG, CTL_EOL);
+                      NULL, 0, &kern_has_sysvmsg, sizeof(int),
+                      CTL_KERN, KERN_SYSVIPC, KERN_SYSVIPC_MSG, CTL_EOL);
        sysctl_createv(clog, 0, NULL, NULL,
-                      CTLFLAG_PERMANENT|CTLFLAG_IMMEDIATE,
+                      CTLFLAG_PERMANENT|CTLFLAG_READONLY,
                       CTLTYPE_INT, "sysvsem",
                       SYSCTL_DESCR("System V style semaphore support "
-                                   "available"), NULL,
-#ifdef SYSVSEM
-                      1,
-#else /* SYSVSEM */
-                      0,
-#endif /* SYSVSEM */
-                      NULL, 0, CTL_KERN, KERN_SYSVIPC, KERN_SYSVIPC_SEM, CTL_EOL);
+                                   "available"),
+                      NULL, 0, &kern_has_sysvsem, sizeof(int),
+                      CTL_KERN, KERN_SYSVIPC, KERN_SYSVIPC_SEM, CTL_EOL);
        sysctl_createv(clog, 0, NULL, NULL,
-                      CTLFLAG_PERMANENT|CTLFLAG_IMMEDIATE,
+                      CTLFLAG_PERMANENT|CTLFLAG_READONLY,
                       CTLTYPE_INT, "sysvshm",
                       SYSCTL_DESCR("System V style shared memory support "
-                                   "available"), NULL,
-#ifdef SYSVSHM
-                      1,
-#else /* SYSVSHM */
-                      0,
-#endif /* SYSVSHM */
-                      NULL, 0, CTL_KERN, KERN_SYSVIPC, KERN_SYSVIPC_SHM, CTL_EOL);
+                                   "available"),
+                      NULL, 0, &kern_has_sysvshm, sizeof(int),
+                      CTL_KERN, KERN_SYSVIPC, KERN_SYSVIPC_SHM, CTL_EOL);
        sysctl_createv(clog, 0, NULL, NULL,
                       CTLFLAG_PERMANENT|CTLFLAG_IMMEDIATE,
                       CTLTYPE_INT, "synchronized_io",
diff -r 01103623d19a -r 496801a14285 sys/kern/sysv_msg.c
--- a/sys/kern/sysv_msg.c       Tue May 12 23:16:47 2015 +0000
+++ b/sys/kern/sysv_msg.c       Wed May 13 01:00:16 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sysv_msg.c,v 1.67 2015/05/12 05:19:20 pgoyette Exp $   */
+/*     $NetBSD: sysv_msg.c,v 1.68 2015/05/13 01:00:16 pgoyette Exp $   */
 
 /*-
  * Copyright (c) 1999, 2006, 2007 The NetBSD Foundation, Inc.
@@ -50,7 +50,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sysv_msg.c,v 1.67 2015/05/12 05:19:20 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sysv_msg.c,v 1.68 2015/05/13 01:00:16 pgoyette Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_sysv.h"
@@ -89,6 +89,8 @@
 
 static void msg_freehdr(struct __msg *);
 
+extern int kern_has_sysvmsg;
+
 void
 msginit(void)
 {
@@ -157,6 +159,8 @@
        cv_init(&msg_realloc_cv, "msgrealc");
        msg_realloc_state = false;
 
+       kern_has_sysvmsg = 1;
+
        sysvipcinit();
 }
 
diff -r 01103623d19a -r 496801a14285 sys/kern/sysv_sem.c
--- a/sys/kern/sysv_sem.c       Tue May 12 23:16:47 2015 +0000
+++ b/sys/kern/sysv_sem.c       Wed May 13 01:00:16 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sysv_sem.c,v 1.92 2015/05/12 05:19:20 pgoyette Exp $   */
+/*     $NetBSD: sysv_sem.c,v 1.93 2015/05/13 01:00:16 pgoyette Exp $   */
 
 /*-
  * Copyright (c) 1999, 2007 The NetBSD Foundation, Inc.
@@ -39,7 +39,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sysv_sem.c,v 1.92 2015/05/12 05:19:20 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sysv_sem.c,v 1.93 2015/05/13 01:00:16 pgoyette Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_sysv.h"
@@ -87,6 +87,10 @@
 #define SEM_PRINTF(a)
 #endif
 
+void *hook;    /* cookie from exithook_establish() */
+
+extern int kern_has_sysvsem;
+
 struct sem_undo *semu_alloc(struct proc *);
 int semundo_adjust(struct proc *, struct sem_undo **, int, int, int);
 void semundo_clear(int, int);
@@ -132,6 +136,8 @@
        semu_list = NULL;
        exithook_establish(semexit, NULL);
 
+       kern_has_sysvsem = 1;
+
        sysvipcinit();
 }
 
diff -r 01103623d19a -r 496801a14285 sys/kern/sysv_shm.c
--- a/sys/kern/sysv_shm.c       Tue May 12 23:16:47 2015 +0000
+++ b/sys/kern/sysv_shm.c       Wed May 13 01:00:16 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sysv_shm.c,v 1.126 2015/05/12 05:19:20 pgoyette Exp $  */
+/*     $NetBSD: sysv_shm.c,v 1.127 2015/05/13 01:00:16 pgoyette Exp $  */
 
 /*-
  * Copyright (c) 1999, 2007 The NetBSD Foundation, Inc.
@@ -61,7 +61,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sysv_shm.c,v 1.126 2015/05/12 05:19:20 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sysv_shm.c,v 1.127 2015/05/13 01:00:16 pgoyette Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_sysv.h"
@@ -108,6 +108,8 @@
        SLIST_HEAD(, shmmap_entry) entries;
 };
 
+extern int kern_has_sysvshm;
+
 #ifdef SHMDEBUG
 #define SHMPRINTF(a) printf a
 #else
@@ -986,6 +988,8 @@
        shm_realloc_disable = 0;
        shm_realloc_state = false;
 
+       kern_has_sysvshm = 1;
+
        sysvipcinit();
 }
 



Home | Main Index | Thread Index | Old Index