2 * Copyright (c) 2003-2013 The DragonFly Project. All rights reserved.
4 * This code is derived from software contributed to The DragonFly Project
5 * by Mihai Carabas <mihai.carabas@gmail.com>
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in
15 * the documentation and/or other materials provided with the
17 * 3. Neither the name of The DragonFly Project nor the names of its
18 * contributors may be used to endorse or promote products derived
19 * from this software without specific, prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
29 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
31 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 #include <sys/systm.h>
36 #include <sys/sysctl.h>
37 #include <sys/eventhandler.h>
39 #include <sys/vkernel.h>
41 #include <machine/vmm.h>
42 #include <machine/cputypes.h>
43 #include <machine/md_var.h>
47 static struct vmm_ctl
*ctl
= NULL
;
49 struct sysctl_ctx_list vmm_sysctl_ctx
;
50 struct sysctl_oid
*vmm_sysctl_tree
;
56 sysctl_vmm_enable(SYSCTL_HANDLER_ARGS
)
60 new_val
= vmm_enabled
;
62 error
= sysctl_handle_int(oidp
, &new_val
, 0, req
);
63 if (error
!= 0 || req
->newptr
== NULL
)
66 if (new_val
!= 0 && new_val
!= 1)
69 if (vmm_enabled
!= new_val
) {
72 kprintf("VMM: vmm enable() failed\n");
75 } else if (new_val
== 0) {
77 kprintf("VMM: vmm disable() failed\n");
85 vmm_enabled
= new_val
;
93 if (vmm_enabled
&& panicstr
== NULL
)
100 sysctl_ctx_init(&vmm_sysctl_ctx
);
101 vmm_sysctl_tree
= SYSCTL_ADD_NODE(&vmm_sysctl_ctx
,
102 SYSCTL_STATIC_CHILDREN(_hw
),
104 CTLFLAG_RD
, 0, "VMM options");
106 if (cpu_vendor_id
== CPU_VENDOR_INTEL
) {
107 ctl
= get_ctl_intel();
108 } else if (cpu_vendor_id
== CPU_VENDOR_AMD
) {
113 SYSCTL_ADD_INT(&vmm_sysctl_ctx
,
114 SYSCTL_CHILDREN(vmm_sysctl_tree
),
115 OID_AUTO
, "enable", CTLFLAG_RD
,
117 "enable not supported");
119 SYSCTL_ADD_STRING(&vmm_sysctl_ctx
,
120 SYSCTL_CHILDREN(vmm_sysctl_tree
),
121 OID_AUTO
, "type", CTLFLAG_RD
,
124 SYSCTL_ADD_PROC(&vmm_sysctl_ctx
,
125 SYSCTL_CHILDREN(vmm_sysctl_tree
),
126 OID_AUTO
, "enable", CTLTYPE_INT
| CTLFLAG_WR
,
127 NULL
, sizeof vmm_enabled
, sysctl_vmm_enable
, "I",
128 "Control the state of the VMM");
129 SYSCTL_ADD_INT(&vmm_sysctl_ctx
,
130 SYSCTL_CHILDREN(vmm_sysctl_tree
),
131 OID_AUTO
, "debug", CTLTYPE_INT
| CTLFLAG_RW
,
136 * Normally enable VMM if it is supported. But for now
137 * lets not, because the vkernel is not stable with it
141 kprintf("VMM: available, disabled by default\n");
142 } else if (ctl
->enable()) {
143 kprintf("VMM: vmm enable() failed\n");
148 EVENTHANDLER_REGISTER(shutdown_pre_sync
, vmm_shutdown
, NULL
, SHUTDOWN_PRI_DEFAULT
-1);
151 SYSINIT(vmm_init
, SI_BOOT2_VMM
, SI_ORDER_ANY
, vmm_init
, NULL
);
155 vmm_vminit(struct vmm_guest_options
*options
)
161 return ctl
->vminit(options
);
170 return ctl
->vmdestroy();
183 vmm_vm_set_tls_area(void)
188 return ctl
->vm_set_tls_area();
192 vmm_vm_set_guest_cr3(register_t guest_cr3
)
194 ctl
->vm_set_guest_cr3(guest_cr3
);
198 vmm_lwp_return(struct lwp
*lp
, struct trapframe
*frame
)
200 ctl
->vm_lwp_return(lp
, frame
);
204 vmm_vm_get_gpa(struct proc
*p
, register_t
*gpa
, register_t uaddr
)
206 return ctl
->vm_get_gpa(p
, gpa
, uaddr
);