From: Stefano Stabellini <sstabellini@kernel.org>
To: peter.maydell@linaro.org, stefanha@gmail.com
Cc: sstabellini@kernel.org, stefanha@redhat.com,
anthony.perard@citrix.com, xen-devel@lists.xenproject.org,
qemu-devel@nongnu.org, Igor Druzhinin <igor.druzhinin@citrix.com>
Subject: [Qemu-devel] [PULL v2 01/15] xen-pvdevice: Introduce a simplistic xen-pvdevice save state
Date: Tue, 22 May 2018 11:46:28 -0700 [thread overview]
Message-ID: <1527014802-11289-1-git-send-email-sstabellini@kernel.org> (raw)
In-Reply-To: <alpine.DEB.2.10.1805221136110.24793@sstabellini-ThinkPad-X260>
From: Igor Druzhinin <igor.druzhinin@citrix.com>
This should help to avoid problems with accessing the device after
migration/resume without PV drivers by migrating its PCI configuration
space state. Without an explicitly defined state record it resets
every time a VM migrates which confuses the OS and makes every
access to xen-pvdevice MMIO region to fail. PV tools enable some
logic to save and restore PCI configuration state from within the VM
every time it migrates which basically hides the issue.
Older systems will acquire the new record when migrated which should
not change their state for worse.
Signed-off-by: Igor Druzhinin <igor.druzhinin@citrix.com>
Reviewed-by: Paul Durrant <paul.durrant@citrix.com>
Acked-by: Anthony PERARD <anthony.perard@citrix.com>
Signed-off-by: Stefano Stabellini <sstabellini@kernel.org>
---
hw/i386/xen/xen_pvdevice.c | 11 +++++++++++
1 file changed, 11 insertions(+)
diff --git a/hw/i386/xen/xen_pvdevice.c b/hw/i386/xen/xen_pvdevice.c
index f748823..a146f18 100644
--- a/hw/i386/xen/xen_pvdevice.c
+++ b/hw/i386/xen/xen_pvdevice.c
@@ -71,6 +71,16 @@ static const MemoryRegionOps xen_pv_mmio_ops = {
.endianness = DEVICE_LITTLE_ENDIAN,
};
+static const VMStateDescription vmstate_xen_pvdevice = {
+ .name = "xen-pvdevice",
+ .version_id = 1,
+ .minimum_version_id = 1,
+ .fields = (VMStateField[]) {
+ VMSTATE_PCI_DEVICE(parent_obj, XenPVDevice),
+ VMSTATE_END_OF_LIST()
+ }
+};
+
static void xen_pv_realize(PCIDevice *pci_dev, Error **errp)
{
XenPVDevice *d = XEN_PV_DEVICE(pci_dev);
@@ -120,6 +130,7 @@ static void xen_pv_class_init(ObjectClass *klass, void *data)
k->class_id = PCI_CLASS_SYSTEM_OTHER;
dc->desc = "Xen PV Device";
dc->props = xen_pv_props;
+ dc->vmsd = &vmstate_xen_pvdevice;
}
static const TypeInfo xen_pv_type_info = {
--
1.9.1
next prev parent reply other threads:[~2018-05-22 18:46 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-05-22 18:46 [Qemu-devel] [PULL v2 00/15] xen-20180522-tag Stefano Stabellini
2018-05-22 18:46 ` Stefano Stabellini [this message]
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 02/15] xen/pt: use address_space_memory object for memory region hooks Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 03/15] configure: Add explanation for --enable-xen-pci-passthrough Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 04/15] xen_pt: Present the size of 64 bit BARs correctly Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 05/15] xen-hvm: create separate function for ioreq server initialization Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 06/15] checkpatch: generalize xen handle matching in the list of types Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 07/15] xen: add a meaningful declaration of grant_copy_segment into xen_common.h Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 08/15] xen_backend: add grant table helpers Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 09/15] xen_disk: remove open-coded use of libxengnttab Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 10/15] xen: remove other " Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 11/15] xen_backend: add an emulation of grant copy Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 12/15] xen_disk: remove use of grant map/unmap Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 13/15] xen_backend: make the xen_feature_grant_copy flag private Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 14/15] xen_disk: use a single entry iovec Stefano Stabellini
2018-05-22 18:46 ` [Qemu-devel] [PULL v2 15/15] xen_disk: be consistent with use of xendev and blkdev->xendev Stefano Stabellini
2018-05-24 12:23 ` [Qemu-devel] [PULL v2 00/15] xen-20180522-tag Peter Maydell
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1527014802-11289-1-git-send-email-sstabellini@kernel.org \
--to=sstabellini@kernel.org \
--cc=anthony.perard@citrix.com \
--cc=igor.druzhinin@citrix.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@gmail.com \
--cc=stefanha@redhat.com \
--cc=xen-devel@lists.xenproject.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).