Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/puffs/mount_sysctlfs Instead of totally giving up, ...
details: https://anonhg.NetBSD.org/src/rev/e118f25b2e9f
branches: trunk
changeset: 753822:e118f25b2e9f
user: pooka <pooka%NetBSD.org@localhost>
date: Sun Apr 11 08:30:17 2010 +0000
description:
Instead of totally giving up, dump CTLTYPE_STRUCT as hex, much
like sysctl -x (but not fancy like -dosequis).
diffstat:
usr.sbin/puffs/mount_sysctlfs/sysctlfs.c | 21 +++++++++++++++------
1 files changed, 15 insertions(+), 6 deletions(-)
diffs (50 lines):
diff -r 90b23632dff5 -r e118f25b2e9f usr.sbin/puffs/mount_sysctlfs/sysctlfs.c
--- a/usr.sbin/puffs/mount_sysctlfs/sysctlfs.c Sun Apr 11 08:23:51 2010 +0000
+++ b/usr.sbin/puffs/mount_sysctlfs/sysctlfs.c Sun Apr 11 08:30:17 2010 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sysctlfs.c,v 1.12 2009/11/05 13:28:20 pooka Exp $ */
+/* $NetBSD: sysctlfs.c,v 1.13 2010/04/11 08:30:17 pooka Exp $ */
/*
* Copyright (c) 2006, 2007 Antti Kantee. All Rights Reserved.
@@ -33,7 +33,7 @@
#include <sys/cdefs.h>
#ifndef lint
-__RCSID("$NetBSD: sysctlfs.c,v 1.12 2009/11/05 13:28:20 pooka Exp $");
+__RCSID("$NetBSD: sysctlfs.c,v 1.13 2010/04/11 08:30:17 pooka Exp $");
#endif /* !lint */
#include <sys/types.h>
@@ -78,7 +78,7 @@
static gid_t filegid;
#define ISADIR(a) ((SYSCTL_TYPE(a->sysctl_flags) == CTLTYPE_NODE))
-#define SFS_MAXFILE 8192
+#define SFS_MAXFILE 32768
#define SFS_NODEPERDIR 128
static int sysctlfs_domount(struct puffs_usermount *);
@@ -395,10 +395,19 @@
snprintf(buf, bufsize, "%" PRId64, q);
break;
}
- case CTLTYPE_STRUCT:
- snprintf(buf, bufsize, "CTLTYPE_STRUCT: implement me and "
- "score a cookie");
+ case CTLTYPE_STRUCT: {
+ uint8_t snode[SFS_MAXFILE/2-1];
+ unsigned i;
+
+ sz = sizeof(snode);
+ if (sysctl(po->po_path, po->po_len, snode, &sz, NULL, 0) == -1)
+ break;
+ for (i = 0; i < sz && 2*i < bufsize; i++) {
+ sprintf(&buf[2*i], "%02x", snode[i]);
+ }
+ buf[2*i] = '\0';
break;
+ }
case CTLTYPE_STRING: {
sz = bufsize;
if (sysctl(po->po_path, po->po_len, buf, &sz, NULL, 0) == -1)
Home |
Main Index |
Thread Index |
Old Index