Module Name:    src
Committed By:   maxv
Date:           Mon Oct 28 13:04:19 UTC 2019

Modified Files:
        src/distrib/sets/lists/base: md.amd64
        src/distrib/sets/lists/man: mi
        src/share/mk: bsd.hostprog.mk
        src/usr.sbin: Makefile
Added Files:
        src/usr.sbin/nvmmctl: Makefile nvmmctl.8 nvmmctl.c

Log Message:
Add nvmmctl, with two commands for now.


To generate a diff of this commit:
cvs rdiff -u -r1.280 -r1.281 src/distrib/sets/lists/base/md.amd64
cvs rdiff -u -r1.1659 -r1.1660 src/distrib/sets/lists/man/mi
cvs rdiff -u -r1.81 -r1.82 src/share/mk/bsd.hostprog.mk
cvs rdiff -u -r1.281 -r1.282 src/usr.sbin/Makefile
cvs rdiff -u -r0 -r1.1 src/usr.sbin/nvmmctl/Makefile \
    src/usr.sbin/nvmmctl/nvmmctl.8 src/usr.sbin/nvmmctl/nvmmctl.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/distrib/sets/lists/base/md.amd64
diff -u src/distrib/sets/lists/base/md.amd64:1.280 src/distrib/sets/lists/base/md.amd64:1.281
--- src/distrib/sets/lists/base/md.amd64:1.280	Mon Aug 26 04:49:45 2019
+++ src/distrib/sets/lists/base/md.amd64	Mon Oct 28 13:04:18 2019
@@ -1,4 +1,4 @@
-# $NetBSD: md.amd64,v 1.280 2019/08/26 04:49:45 kamil Exp $
+# $NetBSD: md.amd64,v 1.281 2019/10/28 13:04:18 maxv Exp $
 ./dev/lms0					base-obsolete		obsolete
 ./dev/mms0					base-obsolete		obsolete
 ./libexec/ld.elf_so-i386			base-sys-shlib		compat,pic
@@ -71,3 +71,4 @@
 ./usr/mdec/pxeboot_ia32_com0.bin		base-obsolete		obsolete
 ./usr/sbin/acpidump				base-sysutil-bin
 ./usr/sbin/amldb				base-sysutil-bin
+./usr/sbin/nvmmctl				base-sysutil-bin

Index: src/distrib/sets/lists/man/mi
diff -u src/distrib/sets/lists/man/mi:1.1659 src/distrib/sets/lists/man/mi:1.1660
--- src/distrib/sets/lists/man/mi:1.1659	Mon Oct 28 02:56:40 2019
+++ src/distrib/sets/lists/man/mi	Mon Oct 28 13:04:18 2019
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.1659 2019/10/28 02:56:40 ozaki-r Exp $
+# $NetBSD: mi,v 1.1660 2019/10/28 13:04:18 maxv Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 #
@@ -2873,6 +2873,7 @@
 ./usr/share/man/cat8/ntptime.0			man-ntp-catman		.cat
 ./usr/share/man/cat8/ntptrace.0			man-ntp-catman		.cat
 ./usr/share/man/cat8/nvmectl.0			man-sysutil-catman	.cat
+./usr/share/man/cat8/nvmmctl.0			man-sysutil-catman	.cat
 ./usr/share/man/cat8/ofctl.0			man-sysutil-catman	.cat
 ./usr/share/man/cat8/ofppc/MAKEDEV.0		man-obsolete		obsolete
 ./usr/share/man/cat8/ofppc/makedev.0		man-obsolete		obsolete
@@ -5823,6 +5824,7 @@
 ./usr/share/man/html8/ntptime.html		man-ntp-htmlman		html
 ./usr/share/man/html8/ntptrace.html		man-ntp-htmlman		html
 ./usr/share/man/html8/nvmectl.html		man-sysutil-htmlman	html
+./usr/share/man/html8/nvmmctl.html		man-sysutil-htmlman	html
 ./usr/share/man/html8/ofctl.html		man-sysutil-htmlman	html
 ./usr/share/man/html8/oqmgr.html		man-postfix-htmlman	postfix,html
 ./usr/share/man/html8/pac.html			man-sysutil-htmlman	html
@@ -8997,6 +8999,7 @@
 ./usr/share/man/man8/ntptime.8			man-ntp-man		.man
 ./usr/share/man/man8/ntptrace.8			man-ntp-man		.man
 ./usr/share/man/man8/nvmectl.8			man-sysutil-man		.man
+./usr/share/man/man8/nvmmctl.8			man-sysutil-man		.man
 ./usr/share/man/man8/ofctl.8			man-sysutil-man		.man
 ./usr/share/man/man8/ofppc/MAKEDEV.8		man-obsolete		obsolete
 ./usr/share/man/man8/ofppc/makedev.8		man-obsolete		obsolete

Index: src/share/mk/bsd.hostprog.mk
diff -u src/share/mk/bsd.hostprog.mk:1.81 src/share/mk/bsd.hostprog.mk:1.82
--- src/share/mk/bsd.hostprog.mk:1.81	Mon Jan 21 21:11:54 2019
+++ src/share/mk/bsd.hostprog.mk	Mon Oct 28 13:04:19 2019
@@ -1,4 +1,4 @@
-#	$NetBSD: bsd.hostprog.mk,v 1.81 2019/01/21 21:11:54 christos Exp $
+#	$NetBSD: bsd.hostprog.mk,v 1.82 2019/10/28 13:04:19 maxv Exp $
 #	@(#)bsd.prog.mk	8.2 (Berkeley) 4/2/94
 
 .include <bsd.hostinit.mk>
@@ -39,6 +39,7 @@ LIBMAGIC?=	/usr/lib/libmagic.a
 LIBMENU?=	/usr/lib/libmenu.a
 LIBMP?=		/usr/lib/libmp.a
 LIBNTP?=	/usr/lib/libntp.a
+LIBNVMM?=	/usr/lib/libnvmm.a
 LIBOBJC?=	/usr/lib/libobjc.a
 LIBP2K?=	/usr/lib/libp2k.a
 LIBPANEL?=	/usr/lib/libpanel.a

Index: src/usr.sbin/Makefile
diff -u src/usr.sbin/Makefile:1.281 src/usr.sbin/Makefile:1.282
--- src/usr.sbin/Makefile:1.281	Tue Oct 15 18:33:23 2019
+++ src/usr.sbin/Makefile	Mon Oct 28 13:04:18 2019
@@ -1,4 +1,4 @@
-#	$NetBSD: Makefile,v 1.281 2019/10/15 18:33:23 christos Exp $
+#	$NetBSD: Makefile,v 1.282 2019/10/28 13:04:18 maxv Exp $
 #	from: @(#)Makefile	5.20 (Berkeley) 6/12/93
 
 .include <bsd.own.mk>
@@ -54,6 +54,8 @@ SUBDIR+=mld6query route6d rtadvd tracero
 
 SUBDIR+= racoon racoonctl
 
+SUBDIR+= nvmmctl
+
 # NPF
 .if (${MKNPF} != "no")
 SUBDIR+=npf

Added files:

Index: src/usr.sbin/nvmmctl/Makefile
diff -u /dev/null src/usr.sbin/nvmmctl/Makefile:1.1
--- /dev/null	Mon Oct 28 13:04:19 2019
+++ src/usr.sbin/nvmmctl/Makefile	Mon Oct 28 13:04:18 2019
@@ -0,0 +1,16 @@
+#	$NetBSD: Makefile,v 1.1 2019/10/28 13:04:18 maxv Exp $
+
+.include <bsd.own.mk>
+
+MAN=	nvmmctl.8
+
+.if (${MACHINE_ARCH} == "x86_64")
+PROG=	nvmmctl
+SRCS=	nvmmctl.c
+
+CPPFLAGS+=-D_KERNTYPES
+LDADD+=-lutil -lnvmm
+DPADD+=${LIBUTIL} ${LIBNVMM}
+.endif
+
+.include <bsd.prog.mk>
Index: src/usr.sbin/nvmmctl/nvmmctl.8
diff -u /dev/null src/usr.sbin/nvmmctl/nvmmctl.8:1.1
--- /dev/null	Mon Oct 28 13:04:19 2019
+++ src/usr.sbin/nvmmctl/nvmmctl.8	Mon Oct 28 13:04:18 2019
@@ -0,0 +1,63 @@
+.\"	$NetBSD: nvmmctl.8,v 1.1 2019/10/28 13:04:18 maxv Exp $
+.\"
+.\" Copyright (c) 2019 The NetBSD Foundation, Inc.
+.\" All rights reserved.
+.\"
+.\" This code is derived from software contributed to The NetBSD Foundation
+.\" by Maxime Villard.
+.\"
+.\" 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.
+.\"
+.Dd October 27, 2019
+.Dt NVMMCTL 8
+.Os
+.Sh NAME
+.Nm nvmmctl
+.Nd program to control virtual machines
+.Sh SYNOPSIS
+.Nm nvmmctl
+.Ar command
+.Op Ar arguments
+.Sh DESCRIPTION
+The
+.Nm
+command can be used to control and inspect the state of virtual machines in the
+system.
+.Pp
+The first argument,
+.Ar command ,
+specifies the action to take.
+Valid commands are:
+.Bl -tag -width XXXXXXXX
+.It identify
+Display the capabilities of the system.
+.It list
+Display information on each virtual machine registered in the system.
+.El
+.Sh SEE ALSO
+.Xr nvmm 4 ,
+.Xr libnvmm 3
+.Sh AUTHORS
+The
+.Nm
+tool was written by
+.An Maxime Villard .
Index: src/usr.sbin/nvmmctl/nvmmctl.c
diff -u /dev/null src/usr.sbin/nvmmctl/nvmmctl.c:1.1
--- /dev/null	Mon Oct 28 13:04:19 2019
+++ src/usr.sbin/nvmmctl/nvmmctl.c	Mon Oct 28 13:04:18 2019
@@ -0,0 +1,180 @@
+/*	$NetBSD: nvmmctl.c,v 1.1 2019/10/28 13:04:18 maxv Exp $	*/
+
+/*
+ * Copyright (c) 2019 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Maxime Villard.
+ *
+ * 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
+__RCSID("$NetBSD: nvmmctl.c,v 1.1 2019/10/28 13:04:18 maxv Exp $");
+#endif /* not lint */
+
+#include <sys/param.h>
+
+#include <err.h>
+#include <errno.h>
+#include <fcntl.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <stdarg.h>
+#include <stdbool.h>
+#include <string.h>
+#include <unistd.h>
+#include <time.h>
+#include <util.h>
+#include <nvmm.h>
+
+#include <x86/specialreg.h>
+
+__dead static void usage(void);
+static void nvmm_identify(char **);
+static void nvmm_list(char **);
+
+static struct cmdtab {
+	const char *label;
+	bool takesargs;
+	bool argsoptional;
+	void (*func)(char **);
+} const nvmm_cmdtab[] = {
+	{ "identify",	false, false, nvmm_identify },
+	{ "list",	false, false, nvmm_list },
+	{ NULL,		false, false, NULL },
+};
+
+static struct nvmm_capability cap;
+
+int
+main(int argc, char **argv)
+{
+	const struct cmdtab *ct;
+
+	argc -= 1;
+	argv += 1;
+	if (argc < 1)
+		usage();
+
+	for (ct = nvmm_cmdtab; ct->label != NULL; ct++) {
+		if (strcmp(argv[0], ct->label) == 0) {
+			if (!ct->argsoptional &&
+			    ((ct->takesargs == 0) ^ (argv[1] == NULL)))
+			{
+				usage();
+			}
+			(*ct->func)(argv + 1);
+			break;
+		}
+	}
+
+	if (ct->label == NULL)
+		errx(EXIT_FAILURE, "unknown command ``%s''", argv[0]);
+
+	exit(EXIT_SUCCESS);
+	/* NOTREACHED */
+}
+
+static void
+usage(void)
+{
+	const char *progname = getprogname();
+
+	fprintf(stderr, "usage: %s identify\n", progname);
+	fprintf(stderr, "       %s list\n", progname);
+	exit(EXIT_FAILURE);
+	/* NOTREACHED */
+}
+
+#define MACH_CONF_FLAGS		"\20"
+#define VCPU_CONF_FLAGS		"\20" "\1" "CPUID" "\2" "TPR"
+
+static void
+nvmm_identify(char **argv)
+{
+	char buf[256], ram[4+1];
+
+	if (nvmm_init() == -1)
+		err(EXIT_FAILURE, "nvmm_init failed");
+	if (nvmm_capability(&cap) == -1)
+		err(EXIT_FAILURE, "nvmm_capability failed");
+
+	printf("nvmm: Kernel API version %u\n", cap.version);
+	printf("nvmm: State size %u\n", cap.state_size);
+	printf("nvmm: Max machines %u\n", cap.max_machines);
+	printf("nvmm: Max VCPUs per machine %u\n", cap.max_vcpus);
+
+	if (humanize_number(ram, sizeof(ram), cap.max_ram, NULL, HN_AUTOSCALE,
+	    (HN_DECIMAL | HN_B | HN_NOSPACE)) == -1)
+		err(EXIT_FAILURE, "humanize_number");
+	printf("nvmm: Max RAM per machine %s\n", ram);
+
+	snprintb(buf, sizeof(buf), MACH_CONF_FLAGS, cap.arch.mach_conf_support);
+	printf("nvmm: Arch Mach conf %s\n", buf);
+
+	snprintb(buf, sizeof(buf), VCPU_CONF_FLAGS, cap.arch.vcpu_conf_support);
+	printf("nvmm: Arch VCPU conf %s\n", buf);
+
+	snprintb(buf, sizeof(buf), XCR0_FLAGS1, cap.arch.xcr0_mask);
+	printf("nvmm: Guest FPU states %s\n", buf);
+}
+
+static void
+nvmm_list(char **argv)
+{
+	struct nvmm_ctl_mach_info machinfo;
+	char ram[4+1], *ts;
+	size_t i;
+	int ret;
+
+	if (nvmm_root_init() == -1)
+		err(EXIT_FAILURE, "nvmm_root_init failed");
+	if (nvmm_capability(&cap) == -1)
+		err(EXIT_FAILURE, "nvmm_capability failed");
+
+	printf(
+	    "Machine ID VCPUs RAM  Owner PID Creation Time           \n"
+	    "---------- ----- ---- --------- ------------------------\n");
+
+	for (i = 0; i < cap.max_machines; i++) {
+		machinfo.machid = i;
+		ret = nvmm_ctl(NVMM_CTL_MACH_INFO, &machinfo, sizeof(machinfo));
+		if (ret == -1) {
+			if (errno == ENOENT)
+				continue;
+			err(EXIT_FAILURE, "nvmm_ctl failed");
+		}
+
+		ts = asctime(localtime(&machinfo.time));
+		ts[strlen(ts) - 1] = '\0';
+
+		if (humanize_number(ram, sizeof(ram), machinfo.nram, NULL,
+		    HN_AUTOSCALE, (HN_DECIMAL | HN_B | HN_NOSPACE)) == -1)
+			err(EXIT_FAILURE, "humanize_number");
+
+		printf("%-10zu %-5u %-4s %-9d %s\n", i, machinfo.nvcpus, ram,
+		    machinfo.pid, ts);
+	}
+}

Reply via email to