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.


SVM: display exit state if incremental exit displays are on
[palacios.git] / palacios / src / palacios / vmm_config_class.h
index bb337c7..0c7ef4c 100644 (file)
@@ -22,8 +22,6 @@
 
 static int pre_config_pc_core(struct guest_info * info, v3_cfg_tree_t * cfg) { 
 
-
-    info->cpu_mode = REAL;
     info->mem_mode = PHYSICAL_MEM;
 
 
@@ -54,32 +52,46 @@ static int post_config_pc(struct v3_vm_info * vm, v3_cfg_tree_t * cfg) {
     {
        extern uint8_t v3_vgabios_start[];
        extern uint8_t v3_vgabios_end[];
-       addr_t vgabios_dst = 0;
+       void * vgabios_dst = 0;
 
-       if (v3_gpa_to_hpa(&(vm->cores[0]), VGABIOS_START, &vgabios_dst) == -1) {
+       if (v3_gpa_to_hva(&(vm->cores[0]), VGABIOS_START, (addr_t *)&vgabios_dst) == -1) {
            PrintError("Could not find VGABIOS destination address\n");
            return -1;
        }
 
-       memcpy(V3_VAddr((void *)vgabios_dst), v3_vgabios_start, 
-              v3_vgabios_end - v3_vgabios_start);      
+       memcpy(vgabios_dst, v3_vgabios_start, v3_vgabios_end - v3_vgabios_start);       
     }
     
     /* layout rombios */
     {
        extern uint8_t v3_rombios_start[];
        extern uint8_t v3_rombios_end[];
-       addr_t rombios_dst = 0;
+       void * rombios_dst = 0;
        
-       if (v3_gpa_to_hpa(&(vm->cores[0]), ROMBIOS_START, &rombios_dst) == -1) {
+       if (v3_gpa_to_hva(&(vm->cores[0]), ROMBIOS_START, (addr_t *)&rombios_dst) == -1) {
            PrintError("Could not find ROMBIOS destination address\n");
            return -1;
        }
 
-       memcpy(V3_VAddr((void *)rombios_dst), v3_rombios_start, 
-              v3_rombios_end - v3_rombios_start);
+       memcpy(rombios_dst, v3_rombios_start, v3_rombios_end - v3_rombios_start);
     }
 
+
+    if (vm->num_cores>1 && !v3_find_dev(vm,"apic")) { 
+       PrintError("palacios: VM has more than one core, but no device named \"apic\"!\n");
+       return -1;
+    } 
+    
+    if (v3_find_dev(vm,"apic")) { 
+       if (!v3_find_dev(vm,"ioapic")) { 
+           PrintError("palacios: VM cores have apics, but there is no device named \"ioapic\"!\n");
+       }
+       if (v3_inject_mptable(vm) == -1) { 
+           PrintError("Failed to inject mptable during configuration\n");
+           return -1;
+       }
+    }
+    
     return 0;
 }