2010-03-19 19:25:33 +03:00
|
|
|
/* $NetBSD: main.c,v 1.10 2010/03/19 16:25:33 pooka Exp $ */
|
2008-01-16 15:34:50 +03:00
|
|
|
|
|
|
|
/*-
|
|
|
|
* Copyright (c) 2008 The NetBSD Foundation, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
|
|
|
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
|
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
|
|
|
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <sys/cdefs.h>
|
|
|
|
#ifndef lint
|
2010-03-19 19:25:33 +03:00
|
|
|
__RCSID("$NetBSD: main.c,v 1.10 2010/03/19 16:25:33 pooka Exp $");
|
2008-01-16 15:34:50 +03:00
|
|
|
#endif /* !lint */
|
|
|
|
|
|
|
|
#include <sys/module.h>
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <err.h>
|
|
|
|
|
|
|
|
int main(int, char **);
|
|
|
|
static void usage(void) __dead;
|
2008-11-16 14:30:55 +03:00
|
|
|
static int modstatcmp(const void *, const void *);
|
2008-01-16 15:34:50 +03:00
|
|
|
|
|
|
|
static const char *classes[] = {
|
|
|
|
"any",
|
|
|
|
"misc",
|
|
|
|
"vfs",
|
|
|
|
"driver",
|
|
|
|
"exec",
|
First part of secmodel cleanup and other misc. changes:
- Separate the suser part of the bsd44 secmodel into its own secmodel
and directory, pending even more cleanups. For revision history
purposes, the original location of the files was
src/sys/secmodel/bsd44/secmodel_bsd44_suser.c
src/sys/secmodel/bsd44/suser.h
- Add a man-page for secmodel_suser(9) and update the one for
secmodel_bsd44(9).
- Add a "secmodel" module class and use it. Userland program and
documentation updated.
- Manage secmodel count (nsecmodels) through the module framework.
This eliminates the need for secmodel_{,de}register() calls in
secmodel code.
- Prepare for secmodel modularization by adding relevant module bits.
The secmodels don't allow auto unload. The bsd44 secmodel depends
on the suser and securelevel secmodels. The overlay secmodel depends
on the bsd44 secmodel. As the module class is only cosmetic, and to
prevent ambiguity, the bsd44 and overlay secmodels are prefixed with
"secmodel_".
- Adapt the overlay secmodel to recent changes (mainly vnode scope).
- Stop using link-sets for the sysctl node(s) creation.
- Keep sysctl variables under nodes of their relevant secmodels. In
other words, don't create duplicates for the suser/securelevel
secmodels under the bsd44 secmodel, as the latter is merely used
for "grouping".
- For the suser and securelevel secmodels, "advertise presence" in
relevant sysctl nodes (sysctl.security.models.{suser,securelevel}).
- Get rid of the LKM preprocessor stuff.
- As secmodels are now modules, there's no need for an explicit call
to secmodel_start(); it's handled by the module framework. That
said, the module framework was adjusted to properly load secmodels
early during system startup.
- Adapt rump to changes: Instead of using empty stubs for securelevel,
simply use the suser secmodel. Also replace secmodel_start() with a
call to secmodel_suser_start().
- 5.99.20.
Testing was done on i386 ("release" build). Spearated module_init()
changes were tested on sparc and sparc64 as well by martin@ (thanks!).
Mailing list reference:
http://mail-index.netbsd.org/tech-kern/2009/09/25/msg006135.html
2009-10-02 22:50:12 +04:00
|
|
|
"secmodel",
|
2008-01-16 15:34:50 +03:00
|
|
|
};
|
2010-03-19 19:25:33 +03:00
|
|
|
const unsigned int class_max = __arraycount(classes);
|
2008-01-16 15:34:50 +03:00
|
|
|
|
|
|
|
static const char *sources[] = {
|
2008-11-15 14:29:04 +03:00
|
|
|
"builtin",
|
2008-01-16 15:34:50 +03:00
|
|
|
"boot",
|
|
|
|
"filesys",
|
|
|
|
};
|
2010-03-19 19:25:33 +03:00
|
|
|
const unsigned int source_max = __arraycount(sources);
|
2008-01-16 15:34:50 +03:00
|
|
|
|
|
|
|
int
|
|
|
|
main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
struct iovec iov;
|
|
|
|
modstat_t *ms;
|
|
|
|
size_t len;
|
|
|
|
const char *name;
|
|
|
|
char sbuf[32];
|
|
|
|
int ch;
|
|
|
|
|
|
|
|
name = NULL;
|
|
|
|
|
|
|
|
while ((ch = getopt(argc, argv, "n:")) != -1) {
|
|
|
|
switch (ch) {
|
|
|
|
case 'n':
|
|
|
|
name = optarg;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
usage();
|
|
|
|
/* NOTREACHED */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
argc -= optind;
|
|
|
|
argv += optind;
|
|
|
|
if (argc != 0)
|
|
|
|
usage();
|
|
|
|
|
2010-03-05 13:27:16 +03:00
|
|
|
for (len = 8192;;) {
|
2008-01-16 15:34:50 +03:00
|
|
|
iov.iov_base = malloc(len);
|
|
|
|
iov.iov_len = len;
|
|
|
|
if (modctl(MODCTL_STAT, &iov)) {
|
|
|
|
err(EXIT_FAILURE, "modctl(MODCTL_STAT)");
|
|
|
|
}
|
|
|
|
if (len >= iov.iov_len) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
free(iov.iov_base);
|
2008-01-19 04:18:47 +03:00
|
|
|
len = iov.iov_len;
|
2008-01-16 15:34:50 +03:00
|
|
|
}
|
|
|
|
|
2009-10-03 06:27:43 +04:00
|
|
|
printf("%-16s %-10s %-10s %-5s %-8s %s\n",
|
|
|
|
"NAME", "CLASS", "SOURCE", "REFS", "SIZE", "REQUIRES");
|
2008-01-16 15:34:50 +03:00
|
|
|
len = iov.iov_len / sizeof(modstat_t);
|
2008-11-16 14:30:55 +03:00
|
|
|
qsort(iov.iov_base, len, sizeof(modstat_t), modstatcmp);
|
2008-01-16 15:34:50 +03:00
|
|
|
for (ms = iov.iov_base; len != 0; ms++, len--) {
|
2010-03-19 19:25:33 +03:00
|
|
|
const char *class;
|
|
|
|
const char *source;
|
|
|
|
|
2008-01-16 15:34:50 +03:00
|
|
|
if (name != NULL && strcmp(ms->ms_name, name) != 0) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (ms->ms_required[0] == '\0') {
|
|
|
|
ms->ms_required[0] = '-';
|
|
|
|
ms->ms_required[1] = '\0';
|
|
|
|
}
|
|
|
|
if (ms->ms_size == 0) {
|
|
|
|
sbuf[0] = '-';
|
|
|
|
sbuf[1] = '\0';
|
|
|
|
} else {
|
|
|
|
snprintf(sbuf, sizeof(sbuf), "%u", ms->ms_size);
|
|
|
|
}
|
2010-03-19 19:25:33 +03:00
|
|
|
if (ms->ms_class <= class_max)
|
|
|
|
class = classes[ms->ms_class];
|
|
|
|
else
|
|
|
|
class = "UNKNOWN";
|
|
|
|
if (ms->ms_source < source_max)
|
|
|
|
source = sources[ms->ms_source];
|
|
|
|
else
|
|
|
|
source = "UNKNOWN";
|
|
|
|
|
2009-10-03 06:27:43 +04:00
|
|
|
printf("%-16s %-10s %-10s %-5d %-8s %s\n",
|
2010-03-19 19:25:33 +03:00
|
|
|
ms->ms_name, class, source, ms->ms_refcnt, sbuf,
|
|
|
|
ms->ms_required);
|
2008-01-16 15:34:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
exit(EXIT_SUCCESS);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
usage(void)
|
|
|
|
{
|
|
|
|
|
2008-11-14 12:55:38 +03:00
|
|
|
(void)fprintf(stderr, "Usage: %s [-n name]\n", getprogname());
|
2008-01-16 15:34:50 +03:00
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
}
|
2008-11-16 14:30:55 +03:00
|
|
|
|
|
|
|
static int
|
|
|
|
modstatcmp(const void *a, const void *b)
|
|
|
|
{
|
|
|
|
const modstat_t *msa, *msb;
|
|
|
|
|
|
|
|
msa = a;
|
|
|
|
msb = b;
|
|
|
|
|
|
|
|
return strcmp(msa->ms_name, msb->ms_name);
|
|
|
|
}
|