summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpjd <pjd@FreeBSD.org>2008-07-21 15:05:25 +0000
committerpjd <pjd@FreeBSD.org>2008-07-21 15:05:25 +0000
commit9d11b5b5b38a8ee6951e205a19c7a74fb7620ce6 (patch)
tree838175217515e587d78333c8470248f0f5bf45f8
parent372e777769c2f1645ab541246f084a3d6977fa61 (diff)
downloadFreeBSD-src-9d11b5b5b38a8ee6951e205a19c7a74fb7620ce6.zip
FreeBSD-src-9d11b5b5b38a8ee6951e205a19c7a74fb7620ce6.tar.gz
Implement the following macros for completeness:
SYSCTL_QUAD() SYSCTL_ADD_QUAD() TUNABLE_QUAD() TUNABLE_QUAD_FETCH() Now we can use 64bit tunables on 32bit systems.
-rw-r--r--share/man/man9/sysctl.97
-rw-r--r--share/man/man9/sysctl_add_oid.914
-rw-r--r--sys/kern/kern_environment.c8
-rw-r--r--sys/sys/kernel.h19
-rw-r--r--sys/sys/sysctl.h9
5 files changed, 55 insertions, 2 deletions
diff --git a/share/man/man9/sysctl.9 b/share/man/man9/sysctl.9
index fe34668..547c8cc 100644
--- a/share/man/man9/sysctl.9
+++ b/share/man/man9/sysctl.9
@@ -40,7 +40,8 @@
.Nm SYSCTL_UINT ,
.Nm SYSCTL_ULONG ,
.Nm SYSCTL_XINT ,
-.Nm SYSCTL_XLONG
+.Nm SYSCTL_XLONG ,
+.Nm SYSCTL_QUAD
.Nd Static sysctl declaration functions
.Sh SYNOPSIS
.In sys/types.h
@@ -57,6 +58,7 @@
.Fn SYSCTL_ULONG parent nbr name access ptr val descr
.Fn SYSCTL_XINT parent nbr name access ptr val descr
.Fn SYSCTL_XLONG parent nbr name access ptr val descr
+.Fn SYSCTL_QUAD parent nbr name access ptr val descr
.Sh DESCRIPTION
The
.Nm SYSCTL
@@ -83,8 +85,9 @@ New nodes are declared using one of
.Fn SYSCTL_UINT ,
.Fn SYSCTL_ULONG ,
.Fn SYSCTL_XINT ,
+.Fn SYSCTL_XLONG ,
and
-.Fn SYSCTL_XLONG .
+.Fn SYSCTL_QUAD .
Each macro accepts a parent name, as declared using
.Fn SYSCTL_DECL ,
an OID number, typically
diff --git a/share/man/man9/sysctl_add_oid.9 b/share/man/man9/sysctl_add_oid.9
index 41de908..43f3112 100644
--- a/share/man/man9/sysctl_add_oid.9
+++ b/share/man/man9/sysctl_add_oid.9
@@ -147,6 +147,16 @@
.Fa "const char *descr"
.Fc
.Ft struct sysctl_oid *
+.Fo SYSCTL_ADD_QUAD
+.Fa "struct sysctl_ctx_list *ctx"
+.Fa "struct sysctl_oid_list *parent"
+.Fa "int number"
+.Fa "const char *name"
+.Fa "int access"
+.Fa "int64_t *arg"
+.Fa "const char *descr"
+.Fc
+.Ft struct sysctl_oid *
.Fo SYSCTL_ADD_OPAQUE
.Fa "struct sysctl_ctx_list *ctx"
.Fa "struct sysctl_oid_list *parent"
@@ -430,6 +440,10 @@ variable.
creates an oid that handles an
.Li unsigned long
variable.
+.It Fn SYSCTL_ADD_QUAD
+creates an oid that handles an
+.Li int64_t
+variable.
.It Fn SYSCTL_ADD_OPAQUE
creates an oid that handles any chunk of opaque data
of the size specified by the
diff --git a/sys/kern/kern_environment.c b/sys/kern/kern_environment.c
index 34b1eec..a5658ca 100644
--- a/sys/kern/kern_environment.c
+++ b/sys/kern/kern_environment.c
@@ -564,6 +564,14 @@ tunable_ulong_init(void *data)
}
void
+tunable_quad_init(void *data)
+{
+ struct tunable_quad *d = (struct tunable_quad *)data;
+
+ TUNABLE_QUAD_FETCH(d->path, d->var);
+}
+
+void
tunable_str_init(void *data)
{
struct tunable_str *d = (struct tunable_str *)data;
diff --git a/sys/sys/kernel.h b/sys/sys/kernel.h
index 951d6bc..e491c6e 100644
--- a/sys/sys/kernel.h
+++ b/sys/sys/kernel.h
@@ -329,6 +329,25 @@ struct tunable_ulong {
#define TUNABLE_ULONG_FETCH(path, var) getenv_ulong((path), (var))
+/*
+ * quad
+ */
+extern void tunable_quad_init(void *);
+struct tunable_quad {
+ const char *path;
+ quad_t *var;
+};
+#define TUNABLE_QUAD(path, var) \
+ static struct tunable_quad __CONCAT(__tunable_quad_, __LINE__) = { \
+ (path), \
+ (var), \
+ }; \
+ SYSINIT(__CONCAT(__Tunable_init_, __LINE__), \
+ SI_SUB_TUNABLES, SI_ORDER_MIDDLE, tunable_quad_init, \
+ &__CONCAT(__tunable_quad_, __LINE__))
+
+#define TUNABLE_QUAD_FETCH(path, var) getenv_quad((path), (var))
+
extern void tunable_str_init(void *);
struct tunable_str {
const char *path;
diff --git a/sys/sys/sysctl.h b/sys/sys/sysctl.h
index ebd83e7..bec41c0 100644
--- a/sys/sys/sysctl.h
+++ b/sys/sys/sysctl.h
@@ -294,6 +294,15 @@ TAILQ_HEAD(sysctl_ctx_list, sysctl_ctx_entry);
sysctl_add_oid(ctx, parent, nbr, name, CTLTYPE_ULONG|(access), \
ptr, 0, sysctl_handle_long, "LX", __DESCR(descr))
+/* Oid for a quad. The pointer must be non NULL. */
+#define SYSCTL_QUAD(parent, nbr, name, access, ptr, val, descr) \
+ SYSCTL_OID(parent, nbr, name, CTLTYPE_QUAD|(access), \
+ ptr, val, sysctl_handle_quad, "Q", __DESCR(descr))
+
+#define SYSCTL_ADD_QUAD(ctx, parent, nbr, name, access, ptr, descr) \
+ sysctl_add_oid(ctx, parent, nbr, name, CTLTYPE_QUAD|(access), \
+ ptr, 0, sysctl_handle_quad, "Q", __DESCR(descr))
+
/* Oid for an opaque object. Specified by a pointer and a length. */
#define SYSCTL_OPAQUE(parent, nbr, name, access, ptr, len, fmt, descr) \
SYSCTL_OID(parent, nbr, name, CTLTYPE_OPAQUE|(access), \
OpenPOWER on IntegriCloud