Palacios Public Git Repository

To checkout Palacios execute

  git clone http://v3vee.org/palacios/palacios.web/palacios.git
This will give you the master branch. You probably want the devel branch or one of the release branches. To switch to the devel branch, simply execute
  cd palacios
  git checkout --track -b devel origin/devel
The other branches are similar.


Merge branch 'devel' of palacios@newskysaw.cs.northwestern.edu:/home/palacios/palacio...
[palacios.git] / palacios / src / extensions / ext_vmware.c
1
2 /* 
3  * This file is part of the Palacios Virtual Machine Monitor developed
4  * by the V3VEE Project with funding from the United States National 
5  * Science Foundation and the Department of Energy.  
6  *
7  * The V3VEE Project is a joint project between Northwestern University
8  * and the University of New Mexico.  You can find out more at 
9  * http://www.v3vee.org
10  *
11  * Copyright (c) 2012, Jack Lange <jarusl@cs.pitt.edu> 
12  * Copyright (c) 2012, The V3VEE Project <http://www.v3vee.org> 
13  * All rights reserved.
14  *
15  * Author: Jack Lange <jarusl@cs.pitt.edu>
16  *
17  * This is free software.  You are permitted to use,
18  * redistribute, and modify it as specified in the file "V3VEE_LICENSE".
19  */
20
21 #include <palacios/vmm.h>
22 #include <palacios/vmm_extensions.h>
23 #include <palacios/vmm_io.h>
24 #include <palacios/vmm_cpuid.h>
25 #include <palacios/vm_guest.h>
26
27
28 #define VMWARE_CPUID_LEAF 0x40000000
29 #define VMWARE_MAGIC 0x564D5868
30 #define VMWARE_IO_PORT  0x5658
31
32 #define VMWARE_IO_VERSION 10
33 #define VMWARE_IO_GETHZ 45
34
35
36 static int io_read(struct guest_info * core, uint16_t port, void * dst, uint_t length, void * priv_data) {
37     uint64_t cpu_hz = V3_CPU_KHZ() * 1000;
38     uint32_t magic = (uint32_t)(core->vm_regs.rax);
39     uint32_t cmd = (uint32_t)(core->vm_regs.rcx);
40
41     PrintError("VMWARE IO READ of size %d (command=%d)\n", length, cmd);
42
43     
44     if (magic != VMWARE_MAGIC) {
45         PrintError("Invalid VMWARE MAgic number in Persona interface, ignoring for now\n");
46         return length;
47     }
48     
49     if (cmd == VMWARE_IO_GETHZ) {
50         // EAX Takes low bytes
51         // EBX takes high bytes
52         core->vm_regs.rax = cpu_hz & 0x00000000ffffffffLL;
53         core->vm_regs.rbx = (cpu_hz >> 32) & 0x00000000ffffffffLL;
54     } else {
55         PrintError("Unhandled VMWARE IO operation\n");
56         return -1;
57     }
58
59     return length;
60 }
61
62
63 static int io_write(struct guest_info * core, uint16_t port, void * src, uint_t length, void * priv_data) {
64
65     PrintError("VMWARE IO PORT WRITE\n");
66     return -1;
67 }
68
69
70 static int vmware_cpuid_handler(struct guest_info * core, uint32_t cpuid, 
71                                 uint32_t * eax, uint32_t * ebx, 
72                                 uint32_t * ecx, uint32_t * edx, 
73                                 void * priv_data) {
74
75     // Don't Care (?)
76     *eax = 0;
77
78     // Set VMWARE Vendor string in EBX,ECX,EDX
79     memcpy(ebx, "VMwa", 4);
80     memcpy(ecx, "reVM", 4);
81     memcpy(edx, "ware", 4);
82     
83     return 0;
84 }
85
86
87
88 static int vmware_init(struct v3_vm_info * vm, v3_cfg_tree_t * cfg, void ** priv_data) {
89
90     V3_Print("Using VMWARE virtualization persona\n");
91
92     v3_cpuid_add_fields(vm, 0x00000001, 
93                         0, 0, 
94                         0, 0, 
95                         0x80000000, 0x80000000,
96                         0, 0
97                         );
98
99
100     v3_hook_io_port(vm, VMWARE_IO_PORT, 
101                     io_read, io_write, 
102                     NULL);
103
104     v3_hook_cpuid(vm, VMWARE_CPUID_LEAF, 
105                   vmware_cpuid_handler, NULL);
106                          
107
108     // hook io port 
109     // set CPUID hypervisor enabled
110     // set VMWare CPUID 
111
112     
113     return 0;
114
115
116 }
117
118
119
120
121 static struct v3_extension_impl vmware_impl = {
122     .name = "VMWARE_IFACE",
123     .init = vmware_init,
124     .deinit = NULL,
125     .core_init = NULL,
126     .core_deinit = NULL,
127     .on_entry = NULL,
128     .on_exit = NULL
129 };
130
131
132
133 register_extension(&vmware_impl);