Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src Reorder the NVMM headers, to make a clear(er) distinction be...
details: https://anonhg.NetBSD.org/src/rev/40baf730ac5c
branches: trunk
changeset: 998717:40baf730ac5c
user: maxv <maxv%NetBSD.org@localhost>
date: Sat Apr 27 15:45:21 2019 +0000
description:
Reorder the NVMM headers, to make a clear(er) distinction between MI and
MD. Also use #defines for the exit reasons rather than an union. No ABI
change, and no API change except 'cap->u.{}' renamed to 'cap->arch'.
diffstat:
lib/libnvmm/nvmm.h | 5 +-
sys/dev/nvmm/nvmm.h | 95 +++++++---------------------------------
sys/dev/nvmm/x86/nvmm_x86.h | 72 ++++++++++++++++++++++++++++++-
sys/dev/nvmm/x86/nvmm_x86_svm.c | 10 ++--
sys/dev/nvmm/x86/nvmm_x86_vmx.c | 10 ++--
5 files changed, 99 insertions(+), 93 deletions(-)
diffs (286 lines):
diff -r 37e50c4bdf66 -r 40baf730ac5c lib/libnvmm/nvmm.h
--- a/lib/libnvmm/nvmm.h Sat Apr 27 15:43:09 2019 +0000
+++ b/lib/libnvmm/nvmm.h Sat Apr 27 15:45:21 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nvmm.h,v 1.8 2019/04/10 18:49:04 maxv Exp $ */
+/* $NetBSD: nvmm.h,v 1.9 2019/04/27 15:45:21 maxv Exp $ */
/*
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -37,9 +37,6 @@
#include <dev/nvmm/nvmm.h>
#include <dev/nvmm/nvmm_ioctl.h>
-#ifdef __x86_64__
-#include <dev/nvmm/x86/nvmm_x86.h>
-#endif
struct nvmm_machine {
nvmm_machid_t machid;
diff -r 37e50c4bdf66 -r 40baf730ac5c sys/dev/nvmm/nvmm.h
--- a/sys/dev/nvmm/nvmm.h Sat Apr 27 15:43:09 2019 +0000
+++ b/sys/dev/nvmm/nvmm.h Sat Apr 27 15:45:21 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nvmm.h,v 1.6 2019/04/24 18:19:28 maxv Exp $ */
+/* $NetBSD: nvmm.h,v 1.7 2019/04/27 15:45:21 maxv Exp $ */
/*
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -44,78 +44,24 @@
typedef uint32_t nvmm_machid_t;
typedef uint32_t nvmm_cpuid_t;
-enum nvmm_exit_reason {
- NVMM_EXIT_NONE = 0x0000000000000000,
-
- /* General. */
- NVMM_EXIT_MEMORY = 0x0000000000000001,
- NVMM_EXIT_IO = 0x0000000000000002,
- NVMM_EXIT_MSR = 0x0000000000000003,
- NVMM_EXIT_INT_READY = 0x0000000000000004,
- NVMM_EXIT_NMI_READY = 0x0000000000000005,
- NVMM_EXIT_HALTED = 0x0000000000000006,
- NVMM_EXIT_SHUTDOWN = 0x0000000000000007,
-
- /* Instructions (x86). */
- NVMM_EXIT_MONITOR = 0x0000000000001000,
- NVMM_EXIT_MWAIT = 0x0000000000001001,
- NVMM_EXIT_MWAIT_COND = 0x0000000000001002,
-
- NVMM_EXIT_INVALID = 0xFFFFFFFFFFFFFFFF
-};
-
-struct nvmm_exit_memory {
- int prot;
- gpaddr_t gpa;
- uint8_t inst_len;
- uint8_t inst_bytes[15];
-};
+#ifdef __x86_64__
+#include <dev/nvmm/x86/nvmm_x86.h>
+#endif
-enum nvmm_exit_io_type {
- NVMM_EXIT_IO_IN,
- NVMM_EXIT_IO_OUT
-};
-
-struct nvmm_exit_io {
- enum nvmm_exit_io_type type;
- uint16_t port;
- int seg;
- uint8_t address_size;
- uint8_t operand_size;
- bool rep;
- bool str;
- uint64_t npc;
-};
-
-enum nvmm_exit_msr_type {
- NVMM_EXIT_MSR_RDMSR,
- NVMM_EXIT_MSR_WRMSR
-};
-
-struct nvmm_exit_msr {
- enum nvmm_exit_msr_type type;
- uint64_t msr;
- uint64_t val;
- uint64_t npc;
-};
-
-struct nvmm_exit_insn {
- uint64_t npc;
-};
-
-struct nvmm_exit_invalid {
- uint64_t hwcode;
-};
+#define NVMM_EXIT_NONE 0x0000000000000000ULL
+#define NVMM_EXIT_MEMORY 0x0000000000000001ULL
+#define NVMM_EXIT_IO 0x0000000000000002ULL
+#define NVMM_EXIT_MSR 0x0000000000000003ULL /* x86 only? */
+#define NVMM_EXIT_INT_READY 0x0000000000000004ULL
+#define NVMM_EXIT_NMI_READY 0x0000000000000005ULL
+#define NVMM_EXIT_HALTED 0x0000000000000006ULL
+#define NVMM_EXIT_SHUTDOWN 0x0000000000000007ULL
+/* Range 0x1000-0x10000 is MD. */
+#define NVMM_EXIT_INVALID 0xFFFFFFFFFFFFFFFFULL
struct nvmm_exit {
- enum nvmm_exit_reason reason;
- union {
- struct nvmm_exit_memory mem;
- struct nvmm_exit_io io;
- struct nvmm_exit_msr msr;
- struct nvmm_exit_insn insn;
- struct nvmm_exit_invalid inv;
- } u;
+ uint64_t reason;
+ union nvmm_exit_md u;
uint64_t exitstate[8];
};
@@ -145,14 +91,7 @@
uint64_t max_machines;
uint64_t max_vcpus;
uint64_t max_ram;
- union {
- struct {
- uint64_t xcr0_mask;
- uint64_t mxcsr_mask;
- uint64_t conf_cpuid_maxops;
- } x86;
- uint64_t rsvd[8];
- } u;
+ struct nvmm_cap_md arch;
};
#endif
diff -r 37e50c4bdf66 -r 40baf730ac5c sys/dev/nvmm/x86/nvmm_x86.h
--- a/sys/dev/nvmm/x86/nvmm_x86.h Sat Apr 27 15:43:09 2019 +0000
+++ b/sys/dev/nvmm/x86/nvmm_x86.h Sat Apr 27 15:45:21 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nvmm_x86.h,v 1.11 2019/04/06 11:49:53 maxv Exp $ */
+/* $NetBSD: nvmm_x86.h,v 1.12 2019/04/27 15:45:21 maxv Exp $ */
/*
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -32,6 +32,76 @@
#ifndef _NVMM_X86_H_
#define _NVMM_X86_H_
+/* --------------------------------------------------------------------- */
+
+#ifndef ASM_NVMM
+
+struct nvmm_exit_memory {
+ int prot;
+ gpaddr_t gpa;
+ uint8_t inst_len;
+ uint8_t inst_bytes[15];
+};
+
+enum nvmm_exit_io_type {
+ NVMM_EXIT_IO_IN,
+ NVMM_EXIT_IO_OUT
+};
+
+struct nvmm_exit_io {
+ enum nvmm_exit_io_type type;
+ uint16_t port;
+ int seg;
+ uint8_t address_size;
+ uint8_t operand_size;
+ bool rep;
+ bool str;
+ uint64_t npc;
+};
+
+enum nvmm_exit_msr_type {
+ NVMM_EXIT_MSR_RDMSR,
+ NVMM_EXIT_MSR_WRMSR
+};
+
+struct nvmm_exit_msr {
+ enum nvmm_exit_msr_type type;
+ uint64_t msr;
+ uint64_t val;
+ uint64_t npc;
+};
+
+struct nvmm_exit_insn {
+ uint64_t npc;
+};
+
+struct nvmm_exit_invalid {
+ uint64_t hwcode;
+};
+
+union nvmm_exit_md {
+ struct nvmm_exit_memory mem;
+ struct nvmm_exit_io io;
+ struct nvmm_exit_msr msr;
+ struct nvmm_exit_insn insn;
+ struct nvmm_exit_invalid inv;
+};
+
+#define NVMM_EXIT_MONITOR 0x0000000000001000ULL
+#define NVMM_EXIT_MWAIT 0x0000000000001001ULL
+#define NVMM_EXIT_MWAIT_COND 0x0000000000001002ULL
+
+struct nvmm_cap_md {
+ uint64_t xcr0_mask;
+ uint64_t mxcsr_mask;
+ uint64_t conf_cpuid_maxops;
+ uint64_t rsvd[5];
+};
+
+#endif
+
+/* --------------------------------------------------------------------- */
+
/* Segments. */
#define NVMM_X64_SEG_ES 0
#define NVMM_X64_SEG_CS 1
diff -r 37e50c4bdf66 -r 40baf730ac5c sys/dev/nvmm/x86/nvmm_x86_svm.c
--- a/sys/dev/nvmm/x86/nvmm_x86_svm.c Sat Apr 27 15:43:09 2019 +0000
+++ b/sys/dev/nvmm/x86/nvmm_x86_svm.c Sat Apr 27 15:45:21 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nvmm_x86_svm.c,v 1.41 2019/04/27 09:06:18 maxv Exp $ */
+/* $NetBSD: nvmm_x86_svm.c,v 1.42 2019/04/27 15:45:21 maxv Exp $ */
/*
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nvmm_x86_svm.c,v 1.41 2019/04/27 09:06:18 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nvmm_x86_svm.c,v 1.42 2019/04/27 15:45:21 maxv Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -2288,9 +2288,9 @@
static void
svm_capability(struct nvmm_capability *cap)
{
- cap->u.x86.xcr0_mask = svm_xcr0_mask;
- cap->u.x86.mxcsr_mask = x86_fpu_mxcsr_mask;
- cap->u.x86.conf_cpuid_maxops = SVM_NCPUIDS;
+ cap->arch.xcr0_mask = svm_xcr0_mask;
+ cap->arch.mxcsr_mask = x86_fpu_mxcsr_mask;
+ cap->arch.conf_cpuid_maxops = SVM_NCPUIDS;
}
const struct nvmm_impl nvmm_x86_svm = {
diff -r 37e50c4bdf66 -r 40baf730ac5c sys/dev/nvmm/x86/nvmm_x86_vmx.c
--- a/sys/dev/nvmm/x86/nvmm_x86_vmx.c Sat Apr 27 15:43:09 2019 +0000
+++ b/sys/dev/nvmm/x86/nvmm_x86_vmx.c Sat Apr 27 15:45:21 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nvmm_x86_vmx.c,v 1.29 2019/04/27 09:06:18 maxv Exp $ */
+/* $NetBSD: nvmm_x86_vmx.c,v 1.30 2019/04/27 15:45:21 maxv Exp $ */
/*
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nvmm_x86_vmx.c,v 1.29 2019/04/27 09:06:18 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nvmm_x86_vmx.c,v 1.30 2019/04/27 15:45:21 maxv Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -3083,9 +3083,9 @@
static void
vmx_capability(struct nvmm_capability *cap)
{
- cap->u.x86.xcr0_mask = vmx_xcr0_mask;
- cap->u.x86.mxcsr_mask = x86_fpu_mxcsr_mask;
- cap->u.x86.conf_cpuid_maxops = VMX_NCPUIDS;
+ cap->arch.xcr0_mask = vmx_xcr0_mask;
+ cap->arch.mxcsr_mask = x86_fpu_mxcsr_mask;
+ cap->arch.conf_cpuid_maxops = VMX_NCPUIDS;
}
const struct nvmm_impl nvmm_x86_vmx = {
Home |
Main Index |
Thread Index |
Old Index