dom0: stores QubesVm.pcidevs as list (#252)
To easier manage pci devices attached to VM
This commit is contained in:
parent
82bc4bad0b
commit
5f10e408e0
dom0
@ -255,9 +255,12 @@ class QubesVm(object):
|
|||||||
|
|
||||||
# PCI devices - used only by NetVM
|
# PCI devices - used only by NetVM
|
||||||
if pcidevs is None or pcidevs == "none":
|
if pcidevs is None or pcidevs == "none":
|
||||||
self.pcidevs = ""
|
self.pcidevs = []
|
||||||
|
elif pcidevs.find('[') < 0:
|
||||||
|
# Backward compatibility
|
||||||
|
self.pcidevs = eval('[' + pcidevs + ']')
|
||||||
else:
|
else:
|
||||||
self.pcidevs = pcidevs
|
self.pcidevs = eval(pcidevs)
|
||||||
|
|
||||||
self.memory = memory
|
self.memory = memory
|
||||||
|
|
||||||
@ -645,7 +648,7 @@ class QubesVm(object):
|
|||||||
args['name'] = self.name
|
args['name'] = self.name
|
||||||
args['kerneldir'] = self.kernels_dir
|
args['kerneldir'] = self.kernels_dir
|
||||||
args['vmdir'] = self.dir_path
|
args['vmdir'] = self.dir_path
|
||||||
args['pcidev'] = self.pcidevs
|
args['pcidev'] = str(self.pcidevs).strip('[]')
|
||||||
args['mem'] = str(self.memory)
|
args['mem'] = str(self.memory)
|
||||||
args['maxmem'] = str(self.maxmem)
|
args['maxmem'] = str(self.maxmem)
|
||||||
args['vcpus'] = str(self.vcpus)
|
args['vcpus'] = str(self.vcpus)
|
||||||
|
@ -140,13 +140,13 @@ def main():
|
|||||||
|
|
||||||
net_devices = find_net_devices()
|
net_devices = find_net_devices()
|
||||||
print "Found the following net devices in your system:"
|
print "Found the following net devices in your system:"
|
||||||
dev_str = ''
|
devs = []
|
||||||
for dev in net_devices:
|
for dev in net_devices:
|
||||||
print "--> {0}".format(dev)
|
print "--> {0}".format(dev)
|
||||||
dev_str += '"{0}", '.format(dev)
|
devs.append(dev)
|
||||||
|
|
||||||
print "Assigning them to the netvm '{0}'".format(vmname)
|
print "Assigning them to the netvm '{0}'".format(vmname)
|
||||||
vm.pcidevs = dev_str
|
vm.pcidevs = str(devs)
|
||||||
|
|
||||||
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)
|
||||||
|
90
dom0/qvm-tools/qvm-pci
Executable file
90
dom0/qvm-tools/qvm-pci
Executable file
@ -0,0 +1,90 @@
|
|||||||
|
#!/usr/bin/python2.6
|
||||||
|
#
|
||||||
|
# The Qubes OS Project, http://www.qubes-os.org
|
||||||
|
#
|
||||||
|
# Copyright (C) 2010 Marek Marczykowski <marmarek@mimuw.edu.pl>
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or
|
||||||
|
# modify it under the terms of the GNU General Public License
|
||||||
|
# as published by the Free Software Foundation; either version 2
|
||||||
|
# of the License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
#
|
||||||
|
#
|
||||||
|
|
||||||
|
from qubes.qubes import QubesVmCollection
|
||||||
|
from optparse import OptionParser
|
||||||
|
import subprocess
|
||||||
|
import os
|
||||||
|
|
||||||
|
def main():
|
||||||
|
usage = "usage: %prog -l [options] <vm-name>\n"\
|
||||||
|
"usage: %prog -a [options] <vm-name> <device>\n"\
|
||||||
|
"usage: %prog -d [options] <vm-name> <device>\n"\
|
||||||
|
"List/set VM PCI devices."
|
||||||
|
|
||||||
|
parser = OptionParser (usage)
|
||||||
|
parser.add_option ("-l", "--list", action="store_true", dest="do_list", default=False)
|
||||||
|
parser.add_option ("-a", "--add", action="store_true", dest="do_add", default=False)
|
||||||
|
parser.add_option ("-d", "--delete", action="store_true", dest="do_delete", default=False)
|
||||||
|
|
||||||
|
(options, args) = parser.parse_args ()
|
||||||
|
if (len (args) < 1):
|
||||||
|
parser.error ("You must provide at least the vmname!")
|
||||||
|
|
||||||
|
vmname = args[0]
|
||||||
|
|
||||||
|
if options.do_list + options.do_add + options.do_delete > 1:
|
||||||
|
print "Only one of -l -a -d is allowed!"
|
||||||
|
exit (1)
|
||||||
|
|
||||||
|
if options.do_add or options.do_delete:
|
||||||
|
qvm_collection = QubesVmCollection()
|
||||||
|
qvm_collection.lock_db_for_writing()
|
||||||
|
qvm_collection.load()
|
||||||
|
else:
|
||||||
|
qvm_collection = QubesVmCollection()
|
||||||
|
qvm_collection.lock_db_for_reading()
|
||||||
|
qvm_collection.load()
|
||||||
|
qvm_collection.unlock_db()
|
||||||
|
|
||||||
|
vm = qvm_collection.get_vm_by_name(vmname)
|
||||||
|
if vm is None or vm.qid not in qvm_collection:
|
||||||
|
print "A VM with the name '{0}' does not exist in the system.".format(vmname)
|
||||||
|
exit(1)
|
||||||
|
|
||||||
|
if options.do_add:
|
||||||
|
if len (args) < 2:
|
||||||
|
print "You must specify the PCI device to add"
|
||||||
|
exit (1)
|
||||||
|
|
||||||
|
pci = args[1]
|
||||||
|
if vm.pcidevs.count(pci) == 0:
|
||||||
|
vm.pcidevs.append(pci)
|
||||||
|
qvm_collection.save()
|
||||||
|
qvm_collection.unlock_db()
|
||||||
|
|
||||||
|
elif options.do_delete:
|
||||||
|
if len (args) < 2:
|
||||||
|
print "You must specify the PCI device to delete"
|
||||||
|
exit (1)
|
||||||
|
|
||||||
|
pci = args[1]
|
||||||
|
if vm.pcidevs.count(pci) > 0:
|
||||||
|
vm.pcidevs.remove(pci)
|
||||||
|
qvm_collection.save()
|
||||||
|
qvm_collection.unlock_db()
|
||||||
|
|
||||||
|
else:
|
||||||
|
# do_list
|
||||||
|
print str(vm.pcidevs)
|
||||||
|
|
||||||
|
main()
|
@ -88,9 +88,9 @@ def set_maxmem(vms, vm, args):
|
|||||||
|
|
||||||
def set_pcidevs(vms, vm, args):
|
def set_pcidevs(vms, vm, args):
|
||||||
if len (args) != 1:
|
if len (args) != 1:
|
||||||
print "Missing memory argument!"
|
print "Missing pcidevs argument!"
|
||||||
|
|
||||||
vm.pcidevs = args[0]
|
vm.pcidevs = list(eval(args[0]))
|
||||||
|
|
||||||
def set_netvm(vms, vm, args):
|
def set_netvm(vms, vm, args):
|
||||||
if len (args) != 1:
|
if len (args) != 1:
|
||||||
|
Loading…
Reference in New Issue
Block a user