2 * This file is part of the Palacios Virtual Machine Monitor developed
3 * by the V3VEE Project with funding from the United States National
4 * Science Foundation and the Department of Energy.
6 * The V3VEE Project is a joint project between Northwestern University
7 * and the University of New Mexico. You can find out more at
10 * Copyright (c) 2008, Jack Lange <jarusl@cs.northwestern.edu>
11 * Copyright (c) 2008, The V3VEE Project <http://www.v3vee.org>
12 * All rights reserved.
14 * Author: Jack Lange <jarusl@cs.northwestern.edu>
16 * This is free software. You are permitted to use,
17 * redistribute, and modify it as specified in the file "V3VEE_LICENSE".
20 #ifndef __VM_GUEST_H__
21 #define __VM_GUEST_H__
25 #include <palacios/vmm_types.h>
26 #include <palacios/vmm_mem.h>
27 #include <palacios/vmm_io.h>
28 #include <palacios/vmm_shadow_paging.h>
29 #include <palacios/vmm_intr.h>
30 #include <palacios/vmm_dev_mgr.h>
31 #include <palacios/vmm_time.h>
32 #include <palacios/vmm_host_events.h>
33 #include <palacios/vmm_msr.h>
34 #include <palacios/vmm_profiler.h>
35 #include <palacios/vmm_hypercall.h>
58 } __attribute__((packed));
93 uint_t granularity : 1;
94 } __attribute__((packed));
100 struct v3_segment es;
101 struct v3_segment fs;
102 struct v3_segment gs;
103 struct v3_segment ss;
104 struct v3_segment ldtr;
105 struct v3_segment gdtr;
106 struct v3_segment idtr;
107 struct v3_segment tr;
110 struct shadow_page_state;
111 struct v3_intr_state;
122 addr_t mem_size; // In bytes for now
123 v3_shdw_map_t mem_map;
126 struct vm_time time_state;
129 v3_paging_mode_t shdw_pg_mode;
130 struct shadow_page_state shdw_pg_state;
131 addr_t direct_map_pt;
132 // nested_paging_t nested_page_state;
135 // This structure is how we get interrupts for the guest
136 struct v3_intr_state intr_state;
140 struct v3_msr_map msr_map;
143 v3_hypercall_map_t hcall_map;
146 struct vmm_dev_mgr dev_mgr;
148 struct v3_host_events host_event_hooks;
150 v3_vm_cpu_mode_t cpu_mode;
151 v3_vm_mem_mode_t mem_mode;
155 struct v3_gprs vm_regs;
156 struct v3_ctrl_regs ctrl_regs;
157 struct v3_dbg_regs dbg_regs;
158 struct v3_segments segments;
160 v3_vm_operating_mode_t run_state;
164 uint_t enable_profiler;
165 struct v3_profiler profiler;
167 void * decoder_state;
171 /* Do we need these ? */
173 v3_msr_t guest_lstar;
174 v3_msr_t guest_cstar;
175 v3_msr_t guest_syscall_mask;
176 v3_msr_t guest_gs_base;
187 uint_t v3_get_addr_width(struct guest_info * info);
188 v3_vm_cpu_mode_t v3_get_cpu_mode(struct guest_info * info);
189 v3_vm_mem_mode_t v3_get_mem_mode(struct guest_info * info);
192 const uchar_t * v3_cpu_mode_to_str(v3_vm_cpu_mode_t mode);
193 const uchar_t * v3_mem_mode_to_str(v3_vm_mem_mode_t mode);
196 void v3_print_segments(struct guest_info * info);
197 void v3_print_ctrl_regs(struct guest_info * info);
198 void v3_print_GPRs(struct guest_info * info);
200 #endif // ! __V3VEE__