[PATCH 00/10] Pass correct qemuCaps to qemuDomainDefPostParse

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Since qemuDomain{Device,}DefPostParse callbacks require qemuCaps, we
need to make sure they get the capabilities stored in the domain's
private data if the domain is running. Passing NULL may cause QEMU
capabilities probing to be triggered in case the cached capabilities are
not valid anymore. When this happens while a running domain object is
locked, QMP event delivered to the domain before QEMU capabilities
probing finishes will deadlock the event loop.

The funny part is that qemuDomainDeviceDefPostParse and
qemuDomainDefPostParse are a callbacks for virDomainDeviceDefPostParse
and virDomainDefPostParse respectively and we need to make sure to
properly set the parseOpaque pointer in all paths which could eventually
go through these general APIs.

If you are interested, you can look at the called-by graph for
virDomainDeviceDefPostParse at
http://people.redhat.com/jdenemar/virDomainDeviceDefPostParse.svg
Only a few of those paths were correct.

Jiri Denemark (10):
  qemu: Pass qemuCaps to qemuDomainDefCopy
  qemu: Pass qemuCaps to qemuDomainDefFormatBufInternal
  qemu: Pass qemuCaps to qemuDomainSaveImageOpen
  qemu: Pass qemuCaps to qemuMigrationAnyPrepareDef
  qemu: Pass correct qemuCaps to virDomainDefParseString
  qemu: Pass qemuCaps to qemuMigrationCookieXMLParse
  qemu: Pass correct qemuCaps to virDomainDefCopy
  qemu: Pass correct qemuCaps to virDomainDefPostParse
  qemu: Pass correct qemuCaps to virDomainDefParseNode
  qemu: Pass correct qemuCaps to virDomainDeviceDefPostParse

 src/conf/checkpoint_conf.c              |   9 +-
 src/conf/checkpoint_conf.h              |   1 +
 src/conf/domain_conf.c                  |  41 ++++---
 src/conf/domain_conf.h                  |  13 ++-
 src/conf/snapshot_conf.c                |  11 +-
 src/conf/snapshot_conf.h                |   2 +
 src/esx/esx_driver.c                    |   2 +-
 src/libxl/libxl_domain.c                |   2 +-
 src/libxl/libxl_driver.c                |  22 ++--
 src/libxl/libxl_migration.c             |   2 +-
 src/lxc/lxc_driver.c                    |  18 +--
 src/lxc/lxc_process.c                   |   2 +-
 src/openvz/openvz_driver.c              |   2 +-
 src/phyp/phyp_driver.c                  |   2 +-
 src/qemu/qemu_domain.c                  |  53 +++++----
 src/qemu/qemu_domain.h                  |   5 +
 src/qemu/qemu_driver.c                  | 149 +++++++++++++++---------
 src/qemu/qemu_migration.c               |  22 ++--
 src/qemu/qemu_migration.h               |   1 +
 src/qemu/qemu_migration_cookie.c        |  16 ++-
 src/qemu/qemu_process.c                 |  13 ++-
 src/test/test_driver.c                  |   7 +-
 src/vbox/vbox_common.c                  |   8 +-
 tests/qemudomaincheckpointxml2xmltest.c |   2 +-
 tests/qemudomainsnapshotxml2xmltest.c   |   2 +-
 tests/qemuhotplugtest.c                 |   4 +-
 26 files changed, 256 insertions(+), 155 deletions(-)

-- 
2.22.0

--
libvir-list mailing list
libvir-list@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/libvir-list



[Index of Archives]     [Virt Tools]     [Libvirt Users]     [Lib OS Info]     [Fedora Users]     [Fedora Desktop]     [Fedora SELinux]     [Big List of Linux Books]     [Yosemite News]     [KDE Users]     [Fedora Tools]

  Powered by Linux