dom0/qvm-create: support for HVM
This commit is contained in:
parent
40d8ac66a3
commit
9c2161944b
@ -37,10 +37,14 @@ def main():
|
|||||||
help="Specify the label to use for the new VM (e.g. red, yellow, green, ...)")
|
help="Specify the label to use for the new VM (e.g. red, yellow, green, ...)")
|
||||||
parser.add_option ("-p", "--proxy", action="store_true", dest="proxyvm", default=False,
|
parser.add_option ("-p", "--proxy", action="store_true", dest="proxyvm", default=False,
|
||||||
help="Create ProxyVM")
|
help="Create ProxyVM")
|
||||||
|
parser.add_option ("-H", "--hvm", action="store_true", dest="hvm", default=False,
|
||||||
|
help="Create HVM (implies --standalone)")
|
||||||
parser.add_option ("-n", "--net", action="store_true", dest="netvm", default=False,
|
parser.add_option ("-n", "--net", action="store_true", dest="netvm", default=False,
|
||||||
help="Create NetVM")
|
help="Create NetVM")
|
||||||
parser.add_option ("-s", "--standalone", action="store_true", dest="standalone", default=False,
|
parser.add_option ("-s", "--standalone", action="store_true", dest="standalone", default=False,
|
||||||
help="Create standalone VM - independent of template ")
|
help="Create standalone VM - independent of template ")
|
||||||
|
parser.add_option ("-r", "--root", dest="root", default=None,
|
||||||
|
help="Use provided root.img instead of default/empty one (file will be MOVED)")
|
||||||
parser.add_option ("-m", "--mem", dest="mem", default=None,
|
parser.add_option ("-m", "--mem", dest="mem", default=None,
|
||||||
help="Initial memory size (in MB)")
|
help="Initial memory size (in MB)")
|
||||||
parser.add_option ("-c", "--vcpus", dest="vcpus", default=None,
|
parser.add_option ("-c", "--vcpus", dest="vcpus", default=None,
|
||||||
@ -82,6 +86,18 @@ def main():
|
|||||||
exit (1)
|
exit (1)
|
||||||
label = QubesVmLabels[options.label]
|
label = QubesVmLabels[options.label]
|
||||||
|
|
||||||
|
if options.hvm:
|
||||||
|
# Only standalone HVMs are supported for now
|
||||||
|
options.standalone = True
|
||||||
|
|
||||||
|
if not options.standalone and options.root is not None:
|
||||||
|
print >> sys.stderr, "root.img can be specified only for standalone VMs"
|
||||||
|
exit (1)
|
||||||
|
|
||||||
|
if options.root is not None and not os.path.exists(options.root):
|
||||||
|
print >> sys.stderr, "File specified as root.img does not exists"
|
||||||
|
exit (1)
|
||||||
|
|
||||||
qvm_collection = QubesVmCollection()
|
qvm_collection = QubesVmCollection()
|
||||||
qvm_collection.lock_db_for_writing()
|
qvm_collection.lock_db_for_writing()
|
||||||
qvm_collection.load()
|
qvm_collection.load()
|
||||||
@ -90,6 +106,7 @@ def main():
|
|||||||
print >> sys.stderr, "A VM with the name '{0}' already exists in the system.".format(vmname)
|
print >> sys.stderr, "A VM with the name '{0}' already exists in the system.".format(vmname)
|
||||||
exit(1)
|
exit(1)
|
||||||
|
|
||||||
|
template_vm = None
|
||||||
if options.template is not None:
|
if options.template is not None:
|
||||||
template_vm = qvm_collection.get_vm_by_name(options.template)
|
template_vm = qvm_collection.get_vm_by_name(options.template)
|
||||||
if template_vm is None:
|
if template_vm is None:
|
||||||
@ -101,7 +118,7 @@ def main():
|
|||||||
if (options.verbose):
|
if (options.verbose):
|
||||||
print "--> Using TemplateVM: {0}".format(template_vm.name)
|
print "--> Using TemplateVM: {0}".format(template_vm.name)
|
||||||
|
|
||||||
else:
|
elif not options.hvm:
|
||||||
if qvm_collection.get_default_template_vm() is None:
|
if qvm_collection.get_default_template_vm() is None:
|
||||||
print >> sys.stderr, "No default TempleteVM defined!"
|
print >> sys.stderr, "No default TempleteVM defined!"
|
||||||
exit (1)
|
exit (1)
|
||||||
@ -120,6 +137,8 @@ def main():
|
|||||||
vm = qvm_collection.add_new_netvm(vmname, new_vm_template, label = label, updateable = options.standalone)
|
vm = qvm_collection.add_new_netvm(vmname, new_vm_template, label = label, updateable = options.standalone)
|
||||||
elif options.proxyvm:
|
elif options.proxyvm:
|
||||||
vm = qvm_collection.add_new_proxyvm(vmname, new_vm_template, label = label, updateable = options.standalone)
|
vm = qvm_collection.add_new_proxyvm(vmname, new_vm_template, label = label, updateable = options.standalone)
|
||||||
|
elif options.hvm:
|
||||||
|
vm = qvm_collection.add_new_hvm(vmname, label = label)
|
||||||
else:
|
else:
|
||||||
vm = qvm_collection.add_new_appvm(vmname, new_vm_template, label = label, updateable = options.standalone)
|
vm = qvm_collection.add_new_appvm(vmname, new_vm_template, label = label, updateable = options.standalone)
|
||||||
|
|
||||||
@ -134,6 +153,9 @@ def main():
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
vm.create_on_disk(verbose=options.verbose, source_template=template_vm)
|
vm.create_on_disk(verbose=options.verbose, source_template=template_vm)
|
||||||
|
if options.root:
|
||||||
|
os.unlink(vm.root_img)
|
||||||
|
os.rename(options.root, vm.root_img)
|
||||||
|
|
||||||
except (IOError, OSError) as err:
|
except (IOError, OSError) as err:
|
||||||
print >> sys.stderr, "ERROR: {0}".format(err)
|
print >> sys.stderr, "ERROR: {0}".format(err)
|
||||||
|
Loading…
Reference in New Issue
Block a user