The following changes since commit e073f74a5a39c6dc45f28a5006c21aa94490d9b8: Merge branch 'this' into vhost (2017-12-07 18:39:24 +0200) are available in the git repository at: git://git.kernel.org/pub/scm/linux/kernel/git/kvms390/linux.git tags/virtio-s390-20171214 for you to fetch changes up to 619b4b0ba832144d4be899640a2047f9675df849: virtio/s390: implement PM operations for virtio_ccw (2017-12-14 10:32:21 +0100) ---------------------------------------------------------------- Hibernation support for virtio-ccw. ---------------------------------------------------------------- Christian Borntraeger (1): virtio/s390: implement PM operations for virtio_ccw drivers/s390/virtio/virtio_ccw.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) -- 2.13.6
Cornelia Huck
2017-Dec-14 09:59 UTC
[PULL 1/1] virtio/s390: implement PM operations for virtio_ccw
From: Christian Borntraeger <borntraeger at de.ibm.com> Suspend/Resume to/from disk currently fails. Let us wire up the necessary callbacks. This is mostly just forwarding the requests to the virtio drivers. The only thing that has to be done in virtio_ccw itself is to re-set the virtio revision. Suggested-by: Thomas Huth <thuth at redhat.com> Signed-off-by: Christian Borntraeger <borntraeger at de.ibm.com> Message-Id: <20171207141102.70190-2-borntraeger at de.ibm.com> Reviewed-by: David Hildenbrand <david at redhat.com> Signed-off-by: Cornelia Huck <cohuck at redhat.com> --- drivers/s390/virtio/virtio_ccw.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/drivers/s390/virtio/virtio_ccw.c b/drivers/s390/virtio/virtio_ccw.c index b18fe2014cf2..330b3fa3430a 100644 --- a/drivers/s390/virtio/virtio_ccw.c +++ b/drivers/s390/virtio/virtio_ccw.c @@ -1300,6 +1300,9 @@ static int virtio_ccw_cio_notify(struct ccw_device *cdev, int event) vcdev->device_lost = true; rc = NOTIFY_DONE; break; + case CIO_OPER: + rc = NOTIFY_OK; + break; default: rc = NOTIFY_DONE; break; @@ -1312,6 +1315,25 @@ static struct ccw_device_id virtio_ids[] = { {}, }; +static int virtio_ccw_freeze(struct ccw_device *cdev) +{ + struct virtio_ccw_device *vcdev = dev_get_drvdata(&cdev->dev); + + return virtio_device_freeze(&vcdev->vdev); +} + +static int virtio_ccw_restore(struct ccw_device *cdev) +{ + struct virtio_ccw_device *vcdev = dev_get_drvdata(&cdev->dev); + int ret; + + ret = virtio_ccw_set_transport_rev(vcdev); + if (ret) + return ret; + + return virtio_device_restore(&vcdev->vdev); +} + static struct ccw_driver virtio_ccw_driver = { .driver = { .owner = THIS_MODULE, @@ -1324,6 +1346,9 @@ static struct ccw_driver virtio_ccw_driver = { .set_online = virtio_ccw_online, .notify = virtio_ccw_cio_notify, .int_class = IRQIO_VIR, + .freeze = virtio_ccw_freeze, + .thaw = virtio_ccw_restore, + .restore = virtio_ccw_restore, }; static int __init pure_hex(char **cp, unsigned int *val, int min_digit, -- 2.13.6
On Thu, 14 Dec 2017 10:59:53 +0100 Cornelia Huck <cohuck at redhat.com> wrote:> The following changes since commit e073f74a5a39c6dc45f28a5006c21aa94490d9b8: > > Merge branch 'this' into vhost (2017-12-07 18:39:24 +0200) > > are available in the git repository at: > > git://git.kernel.org/pub/scm/linux/kernel/git/kvms390/linux.git tags/virtio-s390-20171214 > > for you to fetch changes up to 619b4b0ba832144d4be899640a2047f9675df849: > > virtio/s390: implement PM operations for virtio_ccw (2017-12-14 10:32:21 +0100) > > ---------------------------------------------------------------- > Hibernation support for virtio-ccw. > > ---------------------------------------------------------------- > > Christian Borntraeger (1): > virtio/s390: implement PM operations for virtio_ccw > > drivers/s390/virtio/virtio_ccw.c | 25 +++++++++++++++++++++++++ > 1 file changed, 25 insertions(+) >Self-NAK; this needs a fixup for !CONFIG_PM.