summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorpkelsey <pkelsey@FreeBSD.org>2015-07-15 16:55:56 +0000
committerpkelsey <pkelsey@FreeBSD.org>2015-07-15 16:55:56 +0000
commitdf980625bb6132b2f97b68246dd8d1720425da1f (patch)
treec8f489c76ca2aa64eb851a7445982d6222dc49bb /lib
parent8a1877efc7ed13e92455872c767112736b797b60 (diff)
downloadFreeBSD-src-df980625bb6132b2f97b68246dd8d1720425da1f.zip
FreeBSD-src-df980625bb6132b2f97b68246dd8d1720425da1f.tar.gz
MFC r285188:
Fix sysctl(3) so it returns the intended values for all mib names in the 'user' sysctl tree, which have all been coming back 0 or empty since r240176. Approved by: re
Diffstat (limited to 'lib')
-rw-r--r--lib/libc/gen/sysctl.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/lib/libc/gen/sysctl.c b/lib/libc/gen/sysctl.c
index a5a3d49..b83b439 100644
--- a/lib/libc/gen/sysctl.c
+++ b/lib/libc/gen/sysctl.c
@@ -51,9 +51,21 @@ sysctl(const int *name, u_int namelen, void *oldp, size_t *oldlenp,
const void *newp, size_t newlen)
{
int retval;
+ size_t orig_oldlen;
+ orig_oldlen = oldlenp ? *oldlenp : 0;
retval = __sysctl(name, namelen, oldp, oldlenp, newp, newlen);
- if (retval != -1 || errno != ENOENT || name[0] != CTL_USER)
+ /*
+ * All valid names under CTL_USER have a dummy entry in the sysctl
+ * tree (to support name lookups and enumerations) with an
+ * empty/zero value, and the true value is supplied by this routine.
+ * For all such names, __sysctl() is used solely to validate the
+ * name.
+ *
+ * Return here unless there was a successful lookup for a CTL_USER
+ * name.
+ */
+ if (retval || name[0] != CTL_USER)
return (retval);
if (newp != NULL) {
@@ -67,7 +79,7 @@ sysctl(const int *name, u_int namelen, void *oldp, size_t *oldlenp,
switch (name[1]) {
case USER_CS_PATH:
- if (oldp && *oldlenp < sizeof(_PATH_STDPATH)) {
+ if (oldp && orig_oldlen < sizeof(_PATH_STDPATH)) {
errno = ENOMEM;
return -1;
}
OpenPOWER on IntegriCloud