X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fsvm.h;h=ed227fa298ed0aa21365f62da433f9671a6bbd98;hb=6ee36e0a7e4585bd0e4235eeb60644fffe230af3;hp=3ede354e53a2420994fd23fecc085377aed1b4b2;hpb=90b8236597004a37a9d5acb33a1b1f987fe9070c;p=palacios.git diff --git a/palacios/include/palacios/svm.h b/palacios/include/palacios/svm.h index 3ede354..ed227fa 100644 --- a/palacios/include/palacios/svm.h +++ b/palacios/include/palacios/svm.h @@ -1,21 +1,42 @@ +/* + * This file is part of the Palacios Virtual Machine Monitor developed + * by the V3VEE Project with funding from the United States National + * Science Foundation and the Department of Energy. + * + * The V3VEE Project is a joint project between Northwestern University + * and the University of New Mexico. You can find out more at + * http://www.v3vee.org + * + * Copyright (c) 2008, Jack Lange + * Copyright (c) 2008, The V3VEE Project + * All rights reserved. + * + * Author: Jack Lange + * + * This is free software. You are permitted to use, + * redistribute, and modify it as specified in the file "V3VEE_LICENSE". + */ + #ifndef __SVM_H #define __SVM_H -#include -#include -#include + + #ifdef __V3VEE__ -#define CPUID_FEATURE_IDS 0x80000001 -#define CPUID_FEATURE_IDS_ecx_svm_avail 0x00000004 +#include + + +#include +#include + +#define CPUID_EXT_FEATURE_IDS_ecx_svm_avail 0x00000004 #define CPUID_SVM_REV_AND_FEATURE_IDS 0x8000000a #define CPUID_SVM_REV_AND_FEATURE_IDS_edx_svml 0x00000004 #define CPUID_SVM_REV_AND_FEATURE_IDS_edx_np 0x00000001 - -#define EFER_MSR 0xc0000080 #define EFER_MSR_svm_enable 0x00001000 /************/ @@ -55,12 +76,25 @@ #define SVM_HANDLER_ERROR 0x1 #define SVM_HANDLER_HALT 0x2 -#endif +int v3_is_svm_capable(); + +void v3_init_svm_cpu(int cpu_id); +void v3_deinit_svm_cpu(int cpu_id); -void Init_SVM(struct vmm_ctrl_ops * vmm_ops); -int is_svm_capable(); +int v3_init_svm_vmcb(struct guest_info * core, v3_vm_class_t vm_class); +int v3_deinit_svm_vmcb(struct guest_info * core); + +int v3_svm_enter(struct guest_info * info); +int v3_start_svm_guest(struct guest_info *info); +int v3_reset_svm_vm_core(struct guest_info * core, addr_t rip); + +int v3_svm_load_core(struct guest_info * core, void * ctx); +int v3_svm_save_core(struct guest_info * core, void * ctx); + + +#endif