Boot VMs as HVM when there is a boot CD, regardless of machine type
[invirt/packages/invirt-database.git] / client / etc / xen / sipb-database
index 80af864..1928bba 100644 (file)
@@ -18,7 +18,9 @@ def check(b):
 
 machine = models.Machine.get_by(name=machine_name)
 check(machine is not None)
 
 machine = models.Machine.get_by(name=machine_name)
 check(machine is not None)
-machine_type = models.Type.get_by(type_id=machine.type_id)
+hvm = machine.type.hvm
+if 'cdrom_image' in locals():
+    hvm = True
 
 memory = machine.memory
 maxmem = memory
 
 memory = machine.memory
 maxmem = memory
@@ -32,7 +34,7 @@ vcpus = machine.cpus
 diskioemu = ""
 viftype = ""
 
 diskioemu = ""
 viftype = ""
 
-if machine_type.hvm:
+if hvm:
     ioemu = "ioemu:"
     viftype = "type=ioemu, "
 
     ioemu = "ioemu:"
     viftype = "type=ioemu, "
 
@@ -41,14 +43,15 @@ if machine_type.hvm:
     vnc = 1
     vncpasswd = 'moocow'
     device_model = '/usr/sbin/qemu-dm-sipb'
     vnc = 1
     vncpasswd = 'moocow'
     device_model = '/usr/sbin/qemu-dm-sipb'
+    serial = 'pty'
 else:
     kernel  = '/boot/vmlinuz-2.6.18-5-xen-amd64'
     ramdisk = '/boot/initrd.img-2.6.18-5-xen-amd64'
     builder = 'linux'
 
 else:
     kernel  = '/boot/vmlinuz-2.6.18-5-xen-amd64'
     ramdisk = '/boot/initrd.img-2.6.18-5-xen-amd64'
     builder = 'linux'
 
-pae = machine_type.pae
-acpi = machine_type.acpi
-apic = machine_type.apic
+pae = machine.type.pae
+acpi = machine.type.acpi
+apic = machine.type.apic
 
 vif = []
 
 
 vif = []