Recursive stop VMs, when stopping NetVM (#172)
Dependency resolving in qvm-core, recursive stopping only in qvm-run for now.
This commit is contained in:
parent
01ef2aff9e
commit
6273c42faf
@ -20,6 +20,17 @@
|
||||
|
||||
NETVM=$(qvm-get-default-netvm)
|
||||
|
||||
get_running_netvms() {
|
||||
# Actually get running VMs with PCI devices attached
|
||||
RUNNING_VMS=`xm list --state=Running | tail -n +3 | cut -f 1 -d " "`
|
||||
RUNNING_NETVMS=""
|
||||
for VM in $RUNNING_VMS; do
|
||||
if [ -n "`xm pci-list $VM`" ]; then
|
||||
echo "$VM"
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
start()
|
||||
{
|
||||
if [ x$NETVM = x ] ; then
|
||||
@ -59,8 +70,10 @@ stop()
|
||||
echo -n $"Stopping Qubes networking in Dom0:"
|
||||
else
|
||||
|
||||
echo -n $"Stopping default NetVM:"
|
||||
qvm-run -q --shutdown --wait $NETVM
|
||||
echo -n $"Stopping NetVMs:"
|
||||
for VM in `get_running_netvms`; do
|
||||
qvm-run -q --shutdown --wait $VM
|
||||
done
|
||||
|
||||
fi
|
||||
rm -f /var/lock/subsys/qubes_netvm
|
||||
|
@ -1773,6 +1773,25 @@ class QubesVmCollection(dict):
|
||||
if (vm.is_appvm() and vm.template_vm.qid == template_qid)])
|
||||
return vms
|
||||
|
||||
def get_vms_connected_to(self, netvm_qid):
|
||||
new_vms = [ netvm_qid ]
|
||||
dependend_vms_qid = []
|
||||
|
||||
# Dependency resolving only makes sense on NetVM (or derivative)
|
||||
if not self[netvm_qid].is_netvm():
|
||||
return set([])
|
||||
|
||||
while len(new_vms) > 0:
|
||||
cur_vm = new_vms.pop()
|
||||
for vm in self.values():
|
||||
if vm.netvm_vm and vm.netvm_vm.qid == cur_vm and vm.qid not in dependend_vms_qid:
|
||||
dependend_vms_qid.append(vm.qid)
|
||||
if vm.is_netvm():
|
||||
new_vms.append(vm.qid)
|
||||
|
||||
vms = [vm for vm in self.values() if vm.qid in dependend_vms_qid]
|
||||
return vms
|
||||
|
||||
def verify_new_vm(self, new_vm):
|
||||
|
||||
# Verify that qid is unique
|
||||
|
@ -220,6 +220,11 @@ def main():
|
||||
exit(1)
|
||||
vms_list.append(vm)
|
||||
|
||||
# If stopping NetVM - stop connected VMs too
|
||||
if options.shutdown and vm.is_netvm():
|
||||
vms_list += [vm for vm in qvm_collection.get_vms_connected_to(vm.qid) if vm.is_running()]
|
||||
vms_list.reverse()
|
||||
|
||||
if takes_cmd_argument:
|
||||
cmd = "{user}:{cmd}".format(user=options.user, cmd=cmdstr)
|
||||
else:
|
||||
|
Loading…
Reference in New Issue
Block a user