The branch stable/14 has been updated by zlei:

URL: 
https://cgit.FreeBSD.org/src/commit/?id=615c9ce250ee7c92edf403350ed6663c3f54a1f2

commit 615c9ce250ee7c92edf403350ed6663c3f54a1f2
Author:     Zhenlei Huang <z...@freebsd.org>
AuthorDate: 2024-10-29 11:26:11 +0000
Commit:     Zhenlei Huang <z...@freebsd.org>
CommitDate: 2024-11-16 13:49:45 +0000

    sysctl: Add flags to filter jail prison and vnet variables
    
    So users do not have to contact the source code to tell whether a
    variable is a jail prison / vnet one or not.
    
    Reviewed by:    cy (previous version), markj, jamie (for #jails)
    MFC after:      2 weeks
    Relnotes:       yes
    Differential Revision:  https://reviews.freebsd.org/D47107
    
    (cherry picked from commit 5ec83c660acaf30c1d6b9417dbd8c80dfa9d56ac)
---
 sbin/sysctl/sysctl.8 |  9 +++++++--
 sbin/sysctl/sysctl.c | 18 ++++++++++++++++--
 2 files changed, 23 insertions(+), 4 deletions(-)

diff --git a/sbin/sysctl/sysctl.8 b/sbin/sysctl/sysctl.8
index 70115fa54318..fadc162b80c6 100644
--- a/sbin/sysctl/sysctl.8
+++ b/sbin/sysctl/sysctl.8
@@ -30,7 +30,7 @@
 .\"
 .\"    From: @(#)sysctl.8      8.1 (Berkeley) 6/6/93
 .\"
-.Dd August 18, 2023
+.Dd October 29, 2024
 .Dt SYSCTL 8
 .Os
 .Sh NAME
@@ -113,6 +113,8 @@ The purpose is to make use of
 .Nm
 for collecting data from a variety of machines (not all of which
 are necessarily running exactly the same software) easier.
+.It Fl J
+Display only jail prision sysctl variables (CTLFLAG_PRISON).
 .It Fl l
 Show the length of variables along with their values.
 This option cannot be combined with the
@@ -155,6 +157,8 @@ to standard error.
 Display only variables that are settable via loader (CTLFLAG_TUN).
 .It Fl t
 Print the type of the variable.
+.It Fl V
+Display only VNET sysctl variables (CTLFLAG_VNET).
 .It Fl W
 Display only writable variables that are not statistical.
 Useful for determining the set of runtime tunable sysctls.
@@ -327,7 +331,8 @@ option has been deprecated and is silently ignored.
 .Xr loader.conf 5 ,
 .Xr sysctl.conf 5 ,
 .Xr security 7 ,
-.Xr loader 8
+.Xr loader 8 ,
+.Xr jail 8
 .Sh HISTORY
 A
 .Nm
diff --git a/sbin/sysctl/sysctl.c b/sbin/sysctl/sysctl.c
index df388e41c560..8ec9089bd2cf 100644
--- a/sbin/sysctl/sysctl.c
+++ b/sbin/sysctl/sysctl.c
@@ -64,7 +64,7 @@ static const char *conffile;
 
 static int     aflag, bflag, Bflag, dflag, eflag, hflag, iflag;
 static int     Nflag, nflag, oflag, qflag, tflag, Tflag, Wflag, xflag;
-static bool    Fflag, lflag;
+static bool    Fflag, Jflag, lflag, Vflag;
 
 static int     oidfmt(int *, int, char *, u_int *);
 static int     parsefile(const char *);
@@ -137,7 +137,7 @@ main(int argc, char **argv)
        setbuf(stdout,0);
        setbuf(stderr,0);
 
-       while ((ch = getopt(argc, argv, "AabB:def:FhilNnoqtTwWxX")) != -1) {
+       while ((ch = getopt(argc, argv, "AabB:def:FhiJlNnoqtTVwWxX")) != -1) {
                switch (ch) {
                case 'A':
                        /* compatibility */
@@ -170,6 +170,9 @@ main(int argc, char **argv)
                case 'i':
                        iflag = 1;
                        break;
+               case 'J':
+                       Jflag = true;
+                       break;
                case 'l':
                        lflag = true;
                        break;
@@ -191,6 +194,9 @@ main(int argc, char **argv)
                case 'T':
                        Tflag = 1;
                        break;
+               case 'V':
+                       Vflag = true;
+                       break;
                case 'w':
                        /* compatibility */
                        /* ignored */
@@ -1049,10 +1055,18 @@ show_var(int *oid, int nlen, bool honor_skip)
        if (Wflag && ((kind & CTLFLAG_WR) == 0 || (kind & CTLFLAG_STATS) != 0))
                return (1);
 
+       /* if Jflag then only list sysctls that are prison variables. */
+       if (Jflag && (kind & CTLFLAG_PRISON) == 0)
+               return (1);
+
        /* if Tflag then only list sysctls that are tuneables. */
        if (Tflag && (kind & CTLFLAG_TUN) == 0)
                return (1);
 
+       /* if Vflag then only list sysctls that are vnet variables. */
+       if (Vflag && (kind & CTLFLAG_VNET) == 0)
+               return (1);
+
        if (Nflag) {
                printf("%s", name);
                return (0);

Reply via email to