{"id":815763,"url":"http://patchwork.ozlabs.org/api/covers/815763/?format=json","web_url":"http://patchwork.ozlabs.org/project/qemu-devel/cover/20170919180038.26056-1-dgilbert@redhat.com/","project":{"id":14,"url":"http://patchwork.ozlabs.org/api/projects/14/?format=json","name":"QEMU Development","link_name":"qemu-devel","list_id":"qemu-devel.nongnu.org","list_email":"qemu-devel@nongnu.org","web_url":"","scm_url":"","webscm_url":"","list_archive_url":"","list_archive_url_format":"","commit_url_format":""},"msgid":"<20170919180038.26056-1-dgilbert@redhat.com>","list_archive_url":null,"date":"2017-09-19T18:00:33","name":"[0/5] migration: let pre_save fail","submitter":{"id":48102,"url":"http://patchwork.ozlabs.org/api/people/48102/?format=json","name":"Dr. David Alan Gilbert","email":"dgilbert@redhat.com"},"mbox":"http://patchwork.ozlabs.org/project/qemu-devel/cover/20170919180038.26056-1-dgilbert@redhat.com/mbox/","series":[{"id":3942,"url":"http://patchwork.ozlabs.org/api/series/3942/?format=json","web_url":"http://patchwork.ozlabs.org/project/qemu-devel/list/?series=3942","date":"2017-09-19T18:00:35","name":"migration: let pre_save fail","version":1,"mbox":"http://patchwork.ozlabs.org/series/3942/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/covers/815763/comments/","headers":{"Return-Path":"<qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org>","X-Original-To":"incoming@patchwork.ozlabs.org","Delivered-To":"patchwork-incoming@bilbo.ozlabs.org","Authentication-Results":["ozlabs.org;\n\tspf=pass (mailfrom) smtp.mailfrom=nongnu.org\n\t(client-ip=2001:4830:134:3::11; helo=lists.gnu.org;\n\tenvelope-from=qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org;\n\treceiver=<UNKNOWN>)","ext-mx06.extmail.prod.ext.phx2.redhat.com;\n\tdmarc=none (p=none dis=none) header.from=redhat.com","ext-mx06.extmail.prod.ext.phx2.redhat.com;\n\tspf=fail smtp.mailfrom=dgilbert@redhat.com"],"Received":["from lists.gnu.org (lists.gnu.org [IPv6:2001:4830:134:3::11])\n\t(using TLSv1 with cipher AES256-SHA (256/256 bits))\n\t(No client certificate requested)\n\tby ozlabs.org (Postfix) with ESMTPS id 3xxW0W4jgKz9sBZ\n\tfor <incoming@patchwork.ozlabs.org>;\n\tWed, 20 Sep 2017 04:01:47 +1000 (AEST)","from localhost ([::1]:44643 helo=lists.gnu.org)\n\tby lists.gnu.org with esmtp (Exim 4.71) (envelope-from\n\t<qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org>)\n\tid 1duMq9-0005vF-Ps\n\tfor incoming@patchwork.ozlabs.org; Tue, 19 Sep 2017 14:01:45 -0400","from eggs.gnu.org ([2001:4830:134:3::10]:36956)\n\tby lists.gnu.org with esmtp (Exim 4.71)\n\t(envelope-from <dgilbert@redhat.com>) id 1duMpP-0005si-KB\n\tfor qemu-devel@nongnu.org; Tue, 19 Sep 2017 14:01:00 -0400","from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71)\n\t(envelope-from <dgilbert@redhat.com>) id 1duMpJ-0008G1-Iv\n\tfor qemu-devel@nongnu.org; Tue, 19 Sep 2017 14:00:59 -0400","from mx1.redhat.com ([209.132.183.28]:45344)\n\tby eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32)\n\t(Exim 4.71) (envelope-from <dgilbert@redhat.com>) id 1duMpJ-00087q-9p\n\tfor qemu-devel@nongnu.org; Tue, 19 Sep 2017 14:00:53 -0400","from smtp.corp.redhat.com\n\t(int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14])\n\t(using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits))\n\t(No client certificate requested)\n\tby mx1.redhat.com (Postfix) with ESMTPS id A88593D97B;\n\tTue, 19 Sep 2017 18:00:49 +0000 (UTC)","from dgilbert-t530.redhat.com (ovpn-117-120.ams2.redhat.com\n\t[10.36.117.120])\n\tby smtp.corp.redhat.com (Postfix) with ESMTP id 49F5F5D980;\n\tTue, 19 Sep 2017 18:00:44 +0000 (UTC)"],"DMARC-Filter":"OpenDMARC Filter v1.3.2 mx1.redhat.com A88593D97B","From":"\"Dr. David Alan Gilbert (git)\" <dgilbert@redhat.com>","To":"qemu-devel@nongnu.org,\n\tquintela@redhat.com,\n\tpeterx@redhat.com","Date":"Tue, 19 Sep 2017 19:00:33 +0100","Message-Id":"<20170919180038.26056-1-dgilbert@redhat.com>","X-Scanned-By":"MIMEDefang 2.79 on 10.5.11.14","X-Greylist":"Sender IP whitelisted, not delayed by milter-greylist-4.5.16\n\t(mx1.redhat.com [10.5.110.30]);\n\tTue, 19 Sep 2017 18:00:49 +0000 (UTC)","X-detected-operating-system":"by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic]\n\t[fuzzy]","X-Received-From":"209.132.183.28","Subject":"[Qemu-devel] [PATCH 0/5] migration: let pre_save fail","X-BeenThere":"qemu-devel@nongnu.org","X-Mailman-Version":"2.1.21","Precedence":"list","List-Id":"<qemu-devel.nongnu.org>","List-Unsubscribe":"<https://lists.nongnu.org/mailman/options/qemu-devel>,\n\t<mailto:qemu-devel-request@nongnu.org?subject=unsubscribe>","List-Archive":"<http://lists.nongnu.org/archive/html/qemu-devel/>","List-Post":"<mailto:qemu-devel@nongnu.org>","List-Help":"<mailto:qemu-devel-request@nongnu.org?subject=help>","List-Subscribe":"<https://lists.nongnu.org/mailman/listinfo/qemu-devel>,\n\t<mailto:qemu-devel-request@nongnu.org?subject=subscribe>","Cc":"peter.maydell@linaro.org, cohuck@redhat.com, rth@twiddle.net","Errors-To":"qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org","Sender":"\"Qemu-devel\"\n\t<qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org>"},"content":"From: \"Dr. David Alan Gilbert\" <dgilbert@redhat.com>\n\nAt the moment the pre-save method on VMStateDescription returns void\nwhich means there's no sane way of a pre_save routine failing.  There\nare quite a few pre_save's that abort or do other nasty things, and it\nwould be better if they could fail cleanly.\n\nThis patch series doesn't fix any of those pre_save's - it just changes\npre_save to return an error value and routes that back up so the\nmigration fails.  I'll leave that up to the individual device owners.\n\nThere are a bunch of corner cases that I've not fixed yet;  these are\nmostly places that call vmstate_save_state which have been partially\nconverted to modern migration code;  often the functions they're called\nfrom return void as well - they can get fixed later.\n\nSigned-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>\n\nDr. David Alan Gilbert (5):\n  migration: pre_save return int\n  migration: check pre_save return in vmstate_save_state\n  migration: wire vmstate_save_state errors up to\n    vmstate_subsection_save\n  migration: Route errors up through vmstate_save\n  migration: Route more error paths\n\n docs/devel/migration.txt       |  2 +-\n hw/arm/pxa2xx.c                |  4 +++-\n hw/arm/strongarm.c             |  4 +++-\n hw/audio/wm8750.c              |  4 +++-\n hw/block/fdc.c                 |  4 +++-\n hw/block/m25p80.c              |  4 +++-\n hw/block/nand.c                |  4 +++-\n hw/block/onenand.c             |  4 +++-\n hw/char/serial.c               |  4 +++-\n hw/display/qxl.c               |  4 +++-\n hw/display/virtio-gpu.c        |  4 +---\n hw/i2c/core.c                  |  4 +++-\n hw/i386/kvm/clock.c            |  4 +++-\n hw/ide/core.c                  |  4 +++-\n hw/ide/pci.c                   |  4 +++-\n hw/input/ps2.c                 |  8 ++++++--\n hw/input/tsc210x.c             |  4 +++-\n hw/intc/apic_common.c          |  4 +++-\n hw/intc/arm_gic_common.c       |  4 +++-\n hw/intc/arm_gicv3_common.c     |  4 +++-\n hw/intc/arm_gicv3_its_common.c |  4 +++-\n hw/intc/i8259_common.c         |  4 +++-\n hw/intc/ioapic_common.c        |  4 +++-\n hw/intc/s390_flic_kvm.c        |  6 ++++--\n hw/intc/xics.c                 |  8 ++++++--\n hw/net/e1000.c                 |  4 +++-\n hw/net/e1000e.c                |  4 +++-\n hw/net/rtl8139.c               |  4 +++-\n hw/net/virtio-net.c            | 16 ++++++++++++----\n hw/net/vmxnet3.c               |  4 +++-\n hw/pci-host/piix.c             |  4 +++-\n hw/ppc/ppc.c                   |  4 +++-\n hw/ppc/spapr_iommu.c           |  4 +++-\n hw/ppc/spapr_pci.c             |  6 ++++--\n hw/s390x/css.c                 | 10 +++++++---\n hw/s390x/virtio-ccw.c          |  4 +++-\n hw/scsi/lsi53c895a.c           |  4 +++-\n hw/scsi/vmw_pvscsi.c           |  4 +++-\n hw/timer/cadence_ttc.c         |  4 +++-\n hw/timer/hpet.c                |  4 +++-\n hw/timer/i8254_common.c        |  4 +++-\n hw/timer/mc146818rtc.c         |  4 +++-\n hw/timer/pl031.c               |  4 +++-\n hw/timer/twl92230.c            |  4 +++-\n hw/usb/dev-smartcard-reader.c  |  4 +++-\n hw/usb/hcd-ehci.c              |  4 +++-\n hw/usb/redirect.c              |  4 +++-\n hw/virtio/vhost-vsock.c        |  4 +++-\n hw/virtio/virtio.c             | 13 +++++++------\n include/hw/virtio/virtio.h     |  2 +-\n include/migration/vmstate.h    |  6 +++---\n migration/colo-comm.c          |  4 +++-\n migration/global_state.c       |  4 +++-\n migration/savevm.c             | 23 +++++++++++++++++------\n migration/trace-events         |  1 +\n migration/vmstate-types.c      | 11 ++++++++---\n migration/vmstate.c            | 34 +++++++++++++++++++++++++---------\n replay/replay-snapshot.c       |  4 +++-\n slirp/slirp.c                  |  8 ++++++--\n target/arm/machine.c           |  4 +++-\n target/i386/machine.c          |  7 +++++--\n target/ppc/machine.c           |  4 +++-\n target/s390x/machine.c         |  4 +++-\n target/sparc/machine.c         |  4 +++-\n tests/test-vmstate.c           | 10 ++++++----\n 65 files changed, 261 insertions(+), 102 deletions(-)"}