1 1.12 maxv /* $NetBSD: nvmm_ioctl.h,v 1.12 2020/09/08 16:58:38 maxv Exp $ */ 2 1.1 maxv 3 1.1 maxv /* 4 1.11 maxv * Copyright (c) 2018-2020 Maxime Villard, m00nbsd.net 5 1.1 maxv * All rights reserved. 6 1.1 maxv * 7 1.11 maxv * This code is part of the NVMM hypervisor. 8 1.1 maxv * 9 1.1 maxv * Redistribution and use in source and binary forms, with or without 10 1.1 maxv * modification, are permitted provided that the following conditions 11 1.1 maxv * are met: 12 1.1 maxv * 1. Redistributions of source code must retain the above copyright 13 1.1 maxv * notice, this list of conditions and the following disclaimer. 14 1.1 maxv * 2. Redistributions in binary form must reproduce the above copyright 15 1.1 maxv * notice, this list of conditions and the following disclaimer in the 16 1.1 maxv * documentation and/or other materials provided with the distribution. 17 1.1 maxv * 18 1.11 maxv * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 19 1.11 maxv * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 20 1.11 maxv * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 21 1.11 maxv * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 22 1.11 maxv * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 23 1.11 maxv * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 24 1.11 maxv * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 25 1.11 maxv * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 26 1.11 maxv * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 27 1.11 maxv * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 28 1.11 maxv * SUCH DAMAGE. 29 1.1 maxv */ 30 1.1 maxv 31 1.1 maxv #ifndef _NVMM_IOCTL_H_ 32 1.1 maxv #define _NVMM_IOCTL_H_ 33 1.1 maxv 34 1.12 maxv #include <sys/ioccom.h> 35 1.1 maxv #include <dev/nvmm/nvmm.h> 36 1.1 maxv 37 1.1 maxv struct nvmm_ioc_capability { 38 1.1 maxv struct nvmm_capability cap; 39 1.1 maxv }; 40 1.1 maxv 41 1.1 maxv struct nvmm_ioc_machine_create { 42 1.1 maxv nvmm_machid_t machid; 43 1.1 maxv }; 44 1.1 maxv 45 1.1 maxv struct nvmm_ioc_machine_destroy { 46 1.1 maxv nvmm_machid_t machid; 47 1.1 maxv }; 48 1.1 maxv 49 1.1 maxv struct nvmm_ioc_machine_configure { 50 1.1 maxv nvmm_machid_t machid; 51 1.1 maxv uint64_t op; 52 1.1 maxv void *conf; 53 1.1 maxv }; 54 1.1 maxv 55 1.1 maxv struct nvmm_ioc_vcpu_create { 56 1.1 maxv nvmm_machid_t machid; 57 1.1 maxv nvmm_cpuid_t cpuid; 58 1.1 maxv }; 59 1.1 maxv 60 1.1 maxv struct nvmm_ioc_vcpu_destroy { 61 1.1 maxv nvmm_machid_t machid; 62 1.1 maxv nvmm_cpuid_t cpuid; 63 1.1 maxv }; 64 1.1 maxv 65 1.8 maxv struct nvmm_ioc_vcpu_configure { 66 1.8 maxv nvmm_machid_t machid; 67 1.8 maxv nvmm_cpuid_t cpuid; 68 1.8 maxv uint64_t op; 69 1.8 maxv void *conf; 70 1.8 maxv }; 71 1.8 maxv 72 1.1 maxv struct nvmm_ioc_vcpu_setstate { 73 1.1 maxv nvmm_machid_t machid; 74 1.1 maxv nvmm_cpuid_t cpuid; 75 1.1 maxv }; 76 1.1 maxv 77 1.1 maxv struct nvmm_ioc_vcpu_getstate { 78 1.1 maxv nvmm_machid_t machid; 79 1.1 maxv nvmm_cpuid_t cpuid; 80 1.1 maxv }; 81 1.1 maxv 82 1.1 maxv struct nvmm_ioc_vcpu_inject { 83 1.1 maxv nvmm_machid_t machid; 84 1.1 maxv nvmm_cpuid_t cpuid; 85 1.1 maxv }; 86 1.1 maxv 87 1.1 maxv struct nvmm_ioc_vcpu_run { 88 1.1 maxv /* input */ 89 1.1 maxv nvmm_machid_t machid; 90 1.1 maxv nvmm_cpuid_t cpuid; 91 1.1 maxv /* output */ 92 1.8 maxv struct nvmm_vcpu_exit exit; 93 1.1 maxv }; 94 1.1 maxv 95 1.2 maxv struct nvmm_ioc_hva_map { 96 1.2 maxv nvmm_machid_t machid; 97 1.2 maxv uintptr_t hva; 98 1.2 maxv size_t size; 99 1.2 maxv int flags; 100 1.2 maxv }; 101 1.2 maxv 102 1.2 maxv struct nvmm_ioc_hva_unmap { 103 1.2 maxv nvmm_machid_t machid; 104 1.2 maxv uintptr_t hva; 105 1.2 maxv size_t size; 106 1.2 maxv int flags; 107 1.2 maxv }; 108 1.2 maxv 109 1.1 maxv struct nvmm_ioc_gpa_map { 110 1.1 maxv nvmm_machid_t machid; 111 1.1 maxv uintptr_t hva; 112 1.1 maxv gpaddr_t gpa; 113 1.1 maxv size_t size; 114 1.4 maxv int prot; 115 1.1 maxv }; 116 1.1 maxv 117 1.1 maxv struct nvmm_ioc_gpa_unmap { 118 1.1 maxv nvmm_machid_t machid; 119 1.1 maxv gpaddr_t gpa; 120 1.1 maxv size_t size; 121 1.1 maxv }; 122 1.1 maxv 123 1.5 maxv struct nvmm_ctl_mach_info { 124 1.10 maxv /* input */ 125 1.5 maxv nvmm_machid_t machid; 126 1.10 maxv /* output */ 127 1.9 maxv uint32_t nvcpus; 128 1.9 maxv uint64_t nram; 129 1.5 maxv pid_t pid; 130 1.5 maxv time_t time; 131 1.5 maxv }; 132 1.5 maxv 133 1.5 maxv struct nvmm_ioc_ctl { 134 1.5 maxv int op; 135 1.5 maxv #define NVMM_CTL_MACH_INFO 0 136 1.5 maxv 137 1.5 maxv void *data; 138 1.5 maxv size_t size; 139 1.5 maxv }; 140 1.5 maxv 141 1.1 maxv #define NVMM_IOC_CAPABILITY _IOR ('N', 0, struct nvmm_ioc_capability) 142 1.1 maxv #define NVMM_IOC_MACHINE_CREATE _IOWR('N', 1, struct nvmm_ioc_machine_create) 143 1.1 maxv #define NVMM_IOC_MACHINE_DESTROY _IOW ('N', 2, struct nvmm_ioc_machine_destroy) 144 1.1 maxv #define NVMM_IOC_MACHINE_CONFIGURE _IOW ('N', 3, struct nvmm_ioc_machine_configure) 145 1.1 maxv #define NVMM_IOC_VCPU_CREATE _IOW ('N', 4, struct nvmm_ioc_vcpu_create) 146 1.1 maxv #define NVMM_IOC_VCPU_DESTROY _IOW ('N', 5, struct nvmm_ioc_vcpu_destroy) 147 1.8 maxv #define NVMM_IOC_VCPU_CONFIGURE _IOW ('N', 6, struct nvmm_ioc_vcpu_configure) 148 1.8 maxv #define NVMM_IOC_VCPU_SETSTATE _IOW ('N', 7, struct nvmm_ioc_vcpu_setstate) 149 1.8 maxv #define NVMM_IOC_VCPU_GETSTATE _IOW ('N', 8, struct nvmm_ioc_vcpu_getstate) 150 1.8 maxv #define NVMM_IOC_VCPU_INJECT _IOW ('N', 9, struct nvmm_ioc_vcpu_inject) 151 1.8 maxv #define NVMM_IOC_VCPU_RUN _IOWR('N', 10, struct nvmm_ioc_vcpu_run) 152 1.8 maxv #define NVMM_IOC_GPA_MAP _IOW ('N', 11, struct nvmm_ioc_gpa_map) 153 1.8 maxv #define NVMM_IOC_GPA_UNMAP _IOW ('N', 12, struct nvmm_ioc_gpa_unmap) 154 1.8 maxv #define NVMM_IOC_HVA_MAP _IOW ('N', 13, struct nvmm_ioc_hva_map) 155 1.8 maxv #define NVMM_IOC_HVA_UNMAP _IOW ('N', 14, struct nvmm_ioc_hva_unmap) 156 1.5 maxv #define NVMM_IOC_CTL _IOW ('N', 20, struct nvmm_ioc_ctl) 157 1.5 maxv 158 1.1 maxv #endif /* _NVMM_IOCTL_H_ */ 159