Message ID | 20230804052954.2918915-3-fengli@smartx.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | Fix vhost reconnect issues | expand |
Thanks for the cleanup! A few comments. > On Aug 4, 2023, at 1:29 AM, Li Feng <fengli@smartx.com> wrote: > > Add a Error parameter to report the real error, like vhost-user-blk. > > Signed-off-by: Li Feng <fengli@smartx.com> > --- > hw/scsi/vhost-scsi-common.c | 17 ++++++++++------- > hw/scsi/vhost-scsi.c | 5 +++-- > hw/scsi/vhost-user-scsi.c | 14 ++++++++------ > include/hw/virtio/vhost-scsi-common.h | 2 +- > 4 files changed, 22 insertions(+), 16 deletions(-) > > diff --git a/hw/scsi/vhost-scsi-common.c b/hw/scsi/vhost-scsi-common.c > index a61cd0e907..392587dfb5 100644 > --- a/hw/scsi/vhost-scsi-common.c > +++ b/hw/scsi/vhost-scsi-common.c > @@ -16,6 +16,7 @@ > */ > > #include "qemu/osdep.h" > +#include "qapi/error.h" > #include "qemu/error-report.h" > #include "qemu/module.h" > #include "hw/virtio/vhost.h" > @@ -25,7 +26,7 @@ > #include "hw/virtio/virtio-access.h" > #include "hw/fw-path-provider.h" > > -int vhost_scsi_common_start(VHostSCSICommon *vsc) > +int vhost_scsi_common_start(VHostSCSICommon *vsc, Error **errp) > { > int ret, i; > VirtIODevice *vdev = VIRTIO_DEVICE(vsc); > @@ -35,18 +36,19 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) > VirtIOSCSICommon *vs = (VirtIOSCSICommon *)vsc; > > if (!k->set_guest_notifiers) { > - error_report("binding does not support guest notifiers"); > + error_setg(errp, "binding does not support guest notifiers"); > return -ENOSYS; > } > > ret = vhost_dev_enable_notifiers(&vsc->dev, vdev); > if (ret < 0) { > + error_setg_errno(errp, -ret, "Error enabling host notifiers"); > return ret; > } > > ret = k->set_guest_notifiers(qbus->parent, vsc->dev.nvqs, true); > if (ret < 0) { > - error_report("Error binding guest notifier"); > + error_setg_errno(errp, -ret, "Error binding guest notifier"); > goto err_host_notifiers; > } > > @@ -54,7 +56,7 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) > > ret = vhost_dev_prepare_inflight(&vsc->dev, vdev); > if (ret < 0) { > - error_report("Error setting inflight format: %d", -ret); Curious why you’re adding the error value to the string. Isn’t it redundant since we pass it in as the second param? > + error_setg_errno(errp, -ret, "Error setting inflight format: %d", -ret); > goto err_guest_notifiers; > } > > @@ -64,21 +66,22 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) > vs->conf.virtqueue_size, > vsc->inflight); > if (ret < 0) { > - error_report("Error getting inflight: %d", -ret); Ditto > + error_setg_errno(errp, -ret, "Error getting inflight: %d", > + -ret); > goto err_guest_notifiers; > } > } > > ret = vhost_dev_set_inflight(&vsc->dev, vsc->inflight); > if (ret < 0) { > - error_report("Error setting inflight: %d", -ret); > + error_setg_errno(errp, -ret, "Error setting inflight: %d", -ret); > goto err_guest_notifiers; > } > } > > ret = vhost_dev_start(&vsc->dev, vdev, true); > if (ret < 0) { > - error_report("Error start vhost dev"); “Error starting vhost dev”? > + error_setg_errno(errp, -ret, "Error start vhost dev"); > goto err_guest_notifiers; > } > > diff --git a/hw/scsi/vhost-scsi.c b/hw/scsi/vhost-scsi.c > index 443f67daa4..01a3ab4277 100644 > --- a/hw/scsi/vhost-scsi.c > +++ b/hw/scsi/vhost-scsi.c > @@ -75,6 +75,7 @@ static int vhost_scsi_start(VHostSCSI *s) > int ret, abi_version; > VHostSCSICommon *vsc = VHOST_SCSI_COMMON(s); > const VhostOps *vhost_ops = vsc->dev.vhost_ops; > + Error *local_err = NULL; > > ret = vhost_ops->vhost_scsi_get_abi_version(&vsc->dev, &abi_version); > if (ret < 0) { > @@ -88,14 +89,14 @@ static int vhost_scsi_start(VHostSCSI *s) > return -ENOSYS; > } > > - ret = vhost_scsi_common_start(vsc); > + ret = vhost_scsi_common_start(vsc, &local_err); > if (ret < 0) { > return ret; > } > > ret = vhost_scsi_set_endpoint(s); > if (ret < 0) { > - error_report("Error setting vhost-scsi endpoint"); > + error_reportf_err(local_err, "Error setting vhost-scsi endpoint"); > vhost_scsi_common_stop(vsc); > } > > diff --git a/hw/scsi/vhost-user-scsi.c b/hw/scsi/vhost-user-scsi.c > index a7fa8e8df2..d368171e28 100644 > --- a/hw/scsi/vhost-user-scsi.c > +++ b/hw/scsi/vhost-user-scsi.c > @@ -43,12 +43,12 @@ enum VhostUserProtocolFeature { > VHOST_USER_PROTOCOL_F_RESET_DEVICE = 13, > }; > > -static int vhost_user_scsi_start(VHostUserSCSI *s) > +static int vhost_user_scsi_start(VHostUserSCSI *s, Error **errp) > { > VHostSCSICommon *vsc = VHOST_SCSI_COMMON(s); > int ret; > > - ret = vhost_scsi_common_start(vsc); > + ret = vhost_scsi_common_start(vsc, errp); > s->started_vu = (ret < 0 ? false : true); > > return ret; > @@ -73,6 +73,7 @@ static void vhost_user_scsi_set_status(VirtIODevice *vdev, uint8_t status) > VHostSCSICommon *vsc = VHOST_SCSI_COMMON(s); > VirtIOSCSICommon *vs = VIRTIO_SCSI_COMMON(dev); > bool should_start = virtio_device_should_start(vdev, status); > + Error *local_err = NULL; > int ret; > > if (!s->connected) { > @@ -84,9 +85,10 @@ static void vhost_user_scsi_set_status(VirtIODevice *vdev, uint8_t status) > } > > if (should_start) { > - ret = vhost_user_scsi_start(s); > + ret = vhost_user_scsi_start(s, &local_err); > if (ret < 0) { > - error_report("unable to start vhost-user-scsi: %s", strerror(-ret)); > + error_reportf_err(local_err, "unable to start vhost-user-scsi: %s", > + strerror(-ret)); > qemu_chr_fe_disconnect(&vs->conf.chardev); > } > } else { > @@ -139,7 +141,7 @@ static void vhost_user_scsi_handle_output(VirtIODevice *vdev, VirtQueue *vq) > * Some guests kick before setting VIRTIO_CONFIG_S_DRIVER_OK so start > * vhost here instead of waiting for .set_status(). > */ > - ret = vhost_user_scsi_start(s); > + ret = vhost_user_scsi_start(s, &local_err); > if (ret < 0) { > error_reportf_err(local_err, "vhost-user-scsi: vhost start failed: "); > qemu_chr_fe_disconnect(&vs->conf.chardev); > @@ -184,7 +186,7 @@ static int vhost_user_scsi_connect(DeviceState *dev, Error **errp) > > /* restore vhost state */ > if (virtio_device_started(vdev, vdev->status)) { > - ret = vhost_user_scsi_start(s); > + ret = vhost_user_scsi_start(s, errp); > if (ret < 0) { > return ret; > } > diff --git a/include/hw/virtio/vhost-scsi-common.h b/include/hw/virtio/vhost-scsi-common.h > index 18f115527c..c5d2c09455 100644 > --- a/include/hw/virtio/vhost-scsi-common.h > +++ b/include/hw/virtio/vhost-scsi-common.h > @@ -39,7 +39,7 @@ struct VHostSCSICommon { > struct vhost_inflight *inflight; > }; > > -int vhost_scsi_common_start(VHostSCSICommon *vsc); > +int vhost_scsi_common_start(VHostSCSICommon *vsc, Error **errp); > void vhost_scsi_common_stop(VHostSCSICommon *vsc); > char *vhost_scsi_common_get_fw_dev_path(FWPathProvider *p, BusState *bus, > DeviceState *dev); > -- > 2.41.0 >
> 2023年8月14日 下午8:11,Raphael Norwitz <raphael.norwitz@nutanix.com> 写道: > > Thanks for the cleanup! A few comments. > >> On Aug 4, 2023, at 1:29 AM, Li Feng <fengli@smartx.com> wrote: >> >> Add a Error parameter to report the real error, like vhost-user-blk. >> >> Signed-off-by: Li Feng <fengli@smartx.com> >> --- >> hw/scsi/vhost-scsi-common.c | 17 ++++++++++------- >> hw/scsi/vhost-scsi.c | 5 +++-- >> hw/scsi/vhost-user-scsi.c | 14 ++++++++------ >> include/hw/virtio/vhost-scsi-common.h | 2 +- >> 4 files changed, 22 insertions(+), 16 deletions(-) >> >> diff --git a/hw/scsi/vhost-scsi-common.c b/hw/scsi/vhost-scsi-common.c >> index a61cd0e907..392587dfb5 100644 >> --- a/hw/scsi/vhost-scsi-common.c >> +++ b/hw/scsi/vhost-scsi-common.c >> @@ -16,6 +16,7 @@ >> */ >> >> #include "qemu/osdep.h" >> +#include "qapi/error.h" >> #include "qemu/error-report.h" >> #include "qemu/module.h" >> #include "hw/virtio/vhost.h" >> @@ -25,7 +26,7 @@ >> #include "hw/virtio/virtio-access.h" >> #include "hw/fw-path-provider.h" >> >> -int vhost_scsi_common_start(VHostSCSICommon *vsc) >> +int vhost_scsi_common_start(VHostSCSICommon *vsc, Error **errp) >> { >> int ret, i; >> VirtIODevice *vdev = VIRTIO_DEVICE(vsc); >> @@ -35,18 +36,19 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) >> VirtIOSCSICommon *vs = (VirtIOSCSICommon *)vsc; >> >> if (!k->set_guest_notifiers) { >> - error_report("binding does not support guest notifiers"); >> + error_setg(errp, "binding does not support guest notifiers"); >> return -ENOSYS; >> } >> >> ret = vhost_dev_enable_notifiers(&vsc->dev, vdev); >> if (ret < 0) { >> + error_setg_errno(errp, -ret, "Error enabling host notifiers"); >> return ret; >> } >> >> ret = k->set_guest_notifiers(qbus->parent, vsc->dev.nvqs, true); >> if (ret < 0) { >> - error_report("Error binding guest notifier"); >> + error_setg_errno(errp, -ret, "Error binding guest notifier"); >> goto err_host_notifiers; >> } >> >> @@ -54,7 +56,7 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) >> >> ret = vhost_dev_prepare_inflight(&vsc->dev, vdev); >> if (ret < 0) { >> - error_report("Error setting inflight format: %d", -ret); > > Curious why you’re adding the error value to the string. Isn’t it redundant since we pass it in as the second param? > >> + error_setg_errno(errp, -ret, "Error setting inflight format: %d", -ret); I don’t understand. Here I put the error message in errp, where is redundant? >> goto err_guest_notifiers; >> } >> >> @@ -64,21 +66,22 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) >> vs->conf.virtqueue_size, >> vsc->inflight); >> if (ret < 0) { >> - error_report("Error getting inflight: %d", -ret); > > Ditto > >> + error_setg_errno(errp, -ret, "Error getting inflight: %d", >> + -ret); >> goto err_guest_notifiers; >> } >> } >> >> ret = vhost_dev_set_inflight(&vsc->dev, vsc->inflight); >> if (ret < 0) { >> - error_report("Error setting inflight: %d", -ret); >> + error_setg_errno(errp, -ret, "Error setting inflight: %d", -ret); >> goto err_guest_notifiers; >> } >> } >> >> ret = vhost_dev_start(&vsc->dev, vdev, true); >> if (ret < 0) { >> - error_report("Error start vhost dev"); > > “Error starting vhost dev”? ACK. > >> + error_setg_errno(errp, -ret, "Error start vhost dev"); >> goto err_guest_notifiers; >> } >> >> diff --git a/hw/scsi/vhost-scsi.c b/hw/scsi/vhost-scsi.c >> index 443f67daa4..01a3ab4277 100644 >> --- a/hw/scsi/vhost-scsi.c >> +++ b/hw/scsi/vhost-scsi.c >> @@ -75,6 +75,7 @@ static int vhost_scsi_start(VHostSCSI *s) >> int ret, abi_version; >> VHostSCSICommon *vsc = VHOST_SCSI_COMMON(s); >> const VhostOps *vhost_ops = vsc->dev.vhost_ops; >> + Error *local_err = NULL; >> >> ret = vhost_ops->vhost_scsi_get_abi_version(&vsc->dev, &abi_version); >> if (ret < 0) { >> @@ -88,14 +89,14 @@ static int vhost_scsi_start(VHostSCSI *s) >> return -ENOSYS; >> } >> >> - ret = vhost_scsi_common_start(vsc); >> + ret = vhost_scsi_common_start(vsc, &local_err); >> if (ret < 0) { >> return ret; >> } >> >> ret = vhost_scsi_set_endpoint(s); >> if (ret < 0) { >> - error_report("Error setting vhost-scsi endpoint"); >> + error_reportf_err(local_err, "Error setting vhost-scsi endpoint"); >> vhost_scsi_common_stop(vsc); >> } >> >> diff --git a/hw/scsi/vhost-user-scsi.c b/hw/scsi/vhost-user-scsi.c >> index a7fa8e8df2..d368171e28 100644 >> --- a/hw/scsi/vhost-user-scsi.c >> +++ b/hw/scsi/vhost-user-scsi.c >> @@ -43,12 +43,12 @@ enum VhostUserProtocolFeature { >> VHOST_USER_PROTOCOL_F_RESET_DEVICE = 13, >> }; >> >> -static int vhost_user_scsi_start(VHostUserSCSI *s) >> +static int vhost_user_scsi_start(VHostUserSCSI *s, Error **errp) >> { >> VHostSCSICommon *vsc = VHOST_SCSI_COMMON(s); >> int ret; >> >> - ret = vhost_scsi_common_start(vsc); >> + ret = vhost_scsi_common_start(vsc, errp); >> s->started_vu = (ret < 0 ? false : true); >> >> return ret; >> @@ -73,6 +73,7 @@ static void vhost_user_scsi_set_status(VirtIODevice *vdev, uint8_t status) >> VHostSCSICommon *vsc = VHOST_SCSI_COMMON(s); >> VirtIOSCSICommon *vs = VIRTIO_SCSI_COMMON(dev); >> bool should_start = virtio_device_should_start(vdev, status); >> + Error *local_err = NULL; >> int ret; >> >> if (!s->connected) { >> @@ -84,9 +85,10 @@ static void vhost_user_scsi_set_status(VirtIODevice *vdev, uint8_t status) >> } >> >> if (should_start) { >> - ret = vhost_user_scsi_start(s); >> + ret = vhost_user_scsi_start(s, &local_err); >> if (ret < 0) { >> - error_report("unable to start vhost-user-scsi: %s", strerror(-ret)); >> + error_reportf_err(local_err, "unable to start vhost-user-scsi: %s", >> + strerror(-ret)); >> qemu_chr_fe_disconnect(&vs->conf.chardev); >> } >> } else { >> @@ -139,7 +141,7 @@ static void vhost_user_scsi_handle_output(VirtIODevice *vdev, VirtQueue *vq) >> * Some guests kick before setting VIRTIO_CONFIG_S_DRIVER_OK so start >> * vhost here instead of waiting for .set_status(). >> */ >> - ret = vhost_user_scsi_start(s); >> + ret = vhost_user_scsi_start(s, &local_err); >> if (ret < 0) { >> error_reportf_err(local_err, "vhost-user-scsi: vhost start failed: "); >> qemu_chr_fe_disconnect(&vs->conf.chardev); >> @@ -184,7 +186,7 @@ static int vhost_user_scsi_connect(DeviceState *dev, Error **errp) >> >> /* restore vhost state */ >> if (virtio_device_started(vdev, vdev->status)) { >> - ret = vhost_user_scsi_start(s); >> + ret = vhost_user_scsi_start(s, errp); >> if (ret < 0) { >> return ret; >> } >> diff --git a/include/hw/virtio/vhost-scsi-common.h b/include/hw/virtio/vhost-scsi-common.h >> index 18f115527c..c5d2c09455 100644 >> --- a/include/hw/virtio/vhost-scsi-common.h >> +++ b/include/hw/virtio/vhost-scsi-common.h >> @@ -39,7 +39,7 @@ struct VHostSCSICommon { >> struct vhost_inflight *inflight; >> }; >> >> -int vhost_scsi_common_start(VHostSCSICommon *vsc); >> +int vhost_scsi_common_start(VHostSCSICommon *vsc, Error **errp); >> void vhost_scsi_common_stop(VHostSCSICommon *vsc); >> char *vhost_scsi_common_get_fw_dev_path(FWPathProvider *p, BusState *bus, >> DeviceState *dev); >> -- >> 2.41.0
Li Feng <fengli@smartx.com> writes: >> 2023年8月14日 下午8:11,Raphael Norwitz <raphael.norwitz@nutanix.com> 写道: >> >> Thanks for the cleanup! A few comments. >> >>> On Aug 4, 2023, at 1:29 AM, Li Feng <fengli@smartx.com> wrote: >>> >>> Add a Error parameter to report the real error, like vhost-user-blk. >>> >>> Signed-off-by: Li Feng <fengli@smartx.com> >>> --- >>> hw/scsi/vhost-scsi-common.c | 17 ++++++++++------- >>> hw/scsi/vhost-scsi.c | 5 +++-- >>> hw/scsi/vhost-user-scsi.c | 14 ++++++++------ >>> include/hw/virtio/vhost-scsi-common.h | 2 +- >>> 4 files changed, 22 insertions(+), 16 deletions(-) >>> >>> diff --git a/hw/scsi/vhost-scsi-common.c b/hw/scsi/vhost-scsi-common.c >>> index a61cd0e907..392587dfb5 100644 >>> --- a/hw/scsi/vhost-scsi-common.c >>> +++ b/hw/scsi/vhost-scsi-common.c >>> @@ -16,6 +16,7 @@ >>> */ >>> >>> #include "qemu/osdep.h" >>> +#include "qapi/error.h" >>> #include "qemu/error-report.h" >>> #include "qemu/module.h" >>> #include "hw/virtio/vhost.h" >>> @@ -25,7 +26,7 @@ >>> #include "hw/virtio/virtio-access.h" >>> #include "hw/fw-path-provider.h" >>> >>> -int vhost_scsi_common_start(VHostSCSICommon *vsc) >>> +int vhost_scsi_common_start(VHostSCSICommon *vsc, Error **errp) >>> { >>> int ret, i; >>> VirtIODevice *vdev = VIRTIO_DEVICE(vsc); >>> @@ -35,18 +36,19 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) >>> VirtIOSCSICommon *vs = (VirtIOSCSICommon *)vsc; >>> >>> if (!k->set_guest_notifiers) { >>> - error_report("binding does not support guest notifiers"); >>> + error_setg(errp, "binding does not support guest notifiers"); >>> return -ENOSYS; >>> } >>> >>> ret = vhost_dev_enable_notifiers(&vsc->dev, vdev); >>> if (ret < 0) { >>> + error_setg_errno(errp, -ret, "Error enabling host notifiers"); >>> return ret; >>> } >>> >>> ret = k->set_guest_notifiers(qbus->parent, vsc->dev.nvqs, true); >>> if (ret < 0) { >>> - error_report("Error binding guest notifier"); >>> + error_setg_errno(errp, -ret, "Error binding guest notifier"); >>> goto err_host_notifiers; >>> } >>> >>> @@ -54,7 +56,7 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) >>> >>> ret = vhost_dev_prepare_inflight(&vsc->dev, vdev); >>> if (ret < 0) { >>> - error_report("Error setting inflight format: %d", -ret); >> >> Curious why you’re adding the error value to the string. Isn’t it redundant since we pass it in as the second param? >> >>> + error_setg_errno(errp, -ret, "Error setting inflight format: %d", -ret); > > I don’t understand. Here I put the error message in errp, where is redundant? The error message will come out like Error setting inflight format: 22: Invalid argument You need to drop ": %d". Two remarks: 1. The #1 reason for bad error messages is neglecting to *test* them. 2. Printing errno as a number is needlessly unfriendly to users. [...]
On 21 Aug 2023, at 8:09 PM, Markus Armbruster <armbru@redhat.com> wrote:
Li Feng <fengli@smartx.com> writes:
2023年8月14日 下午8:11,Raphael Norwitz <raphael.norwitz@nutanix.com> 写道:
Thanks for the cleanup! A few comments.
On Aug 4, 2023, at 1:29 AM, Li Feng <fengli@smartx.com> wrote:
Add a Error parameter to report the real error, like vhost-user-blk.
Signed-off-by: Li Feng <fengli@smartx.com>
---
hw/scsi/vhost-scsi-common.c | 17 ++++++++++-------
hw/scsi/vhost-scsi.c | 5 +++--
hw/scsi/vhost-user-scsi.c | 14 ++++++++------
include/hw/virtio/vhost-scsi-common.h | 2 +-
4 files changed, 22 insertions(+), 16 deletions(-)
diff --git a/hw/scsi/vhost-scsi-common.c b/hw/scsi/vhost-scsi-common.c
index a61cd0e907..392587dfb5 100644
--- a/hw/scsi/vhost-scsi-common.c
+++ b/hw/scsi/vhost-scsi-common.c
@@ -16,6 +16,7 @@
*/
#include "qemu/osdep.h"
+#include "qapi/error.h"
#include "qemu/error-report.h"
#include "qemu/module.h"
#include "hw/virtio/vhost.h"
@@ -25,7 +26,7 @@
#include "hw/virtio/virtio-access.h"
#include "hw/fw-path-provider.h"
-int vhost_scsi_common_start(VHostSCSICommon *vsc)
+int vhost_scsi_common_start(VHostSCSICommon *vsc, Error **errp)
{
int ret, i;
VirtIODevice *vdev = VIRTIO_DEVICE(vsc);
@@ -35,18 +36,19 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc)
VirtIOSCSICommon *vs = (VirtIOSCSICommon *)vsc;
if (!k->set_guest_notifiers) {
- error_report("binding does not support guest notifiers");
+ error_setg(errp, "binding does not support guest notifiers");
return -ENOSYS;
}
ret = vhost_dev_enable_notifiers(&vsc->dev, vdev);
if (ret < 0) {
+ error_setg_errno(errp, -ret, "Error enabling host notifiers");
return ret;
}
ret = k->set_guest_notifiers(qbus->parent, vsc->dev.nvqs, true);
if (ret < 0) {
- error_report("Error binding guest notifier");
+ error_setg_errno(errp, -ret, "Error binding guest notifier");
goto err_host_notifiers;
}
@@ -54,7 +56,7 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc)
ret = vhost_dev_prepare_inflight(&vsc->dev, vdev);
if (ret < 0) {
- error_report("Error setting inflight format: %d", -ret);
Curious why you’re adding the error value to the string. Isn’t it redundant
since we pass it in as the second param?
+ error_setg_errno(errp, -ret, "Error setting inflight format: %d",
-ret);
I don’t understand. Here I put the error message in errp, where is
redundant?
The error message will come out like
Error setting inflight format: 22: Invalid argument
You need to drop ": %d".
Two remarks:
1. The #1 reason for bad error messages is neglecting to *test* them.
2. Printing errno as a number is needlessly unfriendly to users.
[...]
Understood! Very thanks, I will fix it in the v2.
diff --git a/hw/scsi/vhost-scsi-common.c b/hw/scsi/vhost-scsi-common.c index a61cd0e907..392587dfb5 100644 --- a/hw/scsi/vhost-scsi-common.c +++ b/hw/scsi/vhost-scsi-common.c @@ -16,6 +16,7 @@ */ #include "qemu/osdep.h" +#include "qapi/error.h" #include "qemu/error-report.h" #include "qemu/module.h" #include "hw/virtio/vhost.h" @@ -25,7 +26,7 @@ #include "hw/virtio/virtio-access.h" #include "hw/fw-path-provider.h" -int vhost_scsi_common_start(VHostSCSICommon *vsc) +int vhost_scsi_common_start(VHostSCSICommon *vsc, Error **errp) { int ret, i; VirtIODevice *vdev = VIRTIO_DEVICE(vsc); @@ -35,18 +36,19 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) VirtIOSCSICommon *vs = (VirtIOSCSICommon *)vsc; if (!k->set_guest_notifiers) { - error_report("binding does not support guest notifiers"); + error_setg(errp, "binding does not support guest notifiers"); return -ENOSYS; } ret = vhost_dev_enable_notifiers(&vsc->dev, vdev); if (ret < 0) { + error_setg_errno(errp, -ret, "Error enabling host notifiers"); return ret; } ret = k->set_guest_notifiers(qbus->parent, vsc->dev.nvqs, true); if (ret < 0) { - error_report("Error binding guest notifier"); + error_setg_errno(errp, -ret, "Error binding guest notifier"); goto err_host_notifiers; } @@ -54,7 +56,7 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) ret = vhost_dev_prepare_inflight(&vsc->dev, vdev); if (ret < 0) { - error_report("Error setting inflight format: %d", -ret); + error_setg_errno(errp, -ret, "Error setting inflight format: %d", -ret); goto err_guest_notifiers; } @@ -64,21 +66,22 @@ int vhost_scsi_common_start(VHostSCSICommon *vsc) vs->conf.virtqueue_size, vsc->inflight); if (ret < 0) { - error_report("Error getting inflight: %d", -ret); + error_setg_errno(errp, -ret, "Error getting inflight: %d", + -ret); goto err_guest_notifiers; } } ret = vhost_dev_set_inflight(&vsc->dev, vsc->inflight); if (ret < 0) { - error_report("Error setting inflight: %d", -ret); + error_setg_errno(errp, -ret, "Error setting inflight: %d", -ret); goto err_guest_notifiers; } } ret = vhost_dev_start(&vsc->dev, vdev, true); if (ret < 0) { - error_report("Error start vhost dev"); + error_setg_errno(errp, -ret, "Error start vhost dev"); goto err_guest_notifiers; } diff --git a/hw/scsi/vhost-scsi.c b/hw/scsi/vhost-scsi.c index 443f67daa4..01a3ab4277 100644 --- a/hw/scsi/vhost-scsi.c +++ b/hw/scsi/vhost-scsi.c @@ -75,6 +75,7 @@ static int vhost_scsi_start(VHostSCSI *s) int ret, abi_version; VHostSCSICommon *vsc = VHOST_SCSI_COMMON(s); const VhostOps *vhost_ops = vsc->dev.vhost_ops; + Error *local_err = NULL; ret = vhost_ops->vhost_scsi_get_abi_version(&vsc->dev, &abi_version); if (ret < 0) { @@ -88,14 +89,14 @@ static int vhost_scsi_start(VHostSCSI *s) return -ENOSYS; } - ret = vhost_scsi_common_start(vsc); + ret = vhost_scsi_common_start(vsc, &local_err); if (ret < 0) { return ret; } ret = vhost_scsi_set_endpoint(s); if (ret < 0) { - error_report("Error setting vhost-scsi endpoint"); + error_reportf_err(local_err, "Error setting vhost-scsi endpoint"); vhost_scsi_common_stop(vsc); } diff --git a/hw/scsi/vhost-user-scsi.c b/hw/scsi/vhost-user-scsi.c index a7fa8e8df2..d368171e28 100644 --- a/hw/scsi/vhost-user-scsi.c +++ b/hw/scsi/vhost-user-scsi.c @@ -43,12 +43,12 @@ enum VhostUserProtocolFeature { VHOST_USER_PROTOCOL_F_RESET_DEVICE = 13, }; -static int vhost_user_scsi_start(VHostUserSCSI *s) +static int vhost_user_scsi_start(VHostUserSCSI *s, Error **errp) { VHostSCSICommon *vsc = VHOST_SCSI_COMMON(s); int ret; - ret = vhost_scsi_common_start(vsc); + ret = vhost_scsi_common_start(vsc, errp); s->started_vu = (ret < 0 ? false : true); return ret; @@ -73,6 +73,7 @@ static void vhost_user_scsi_set_status(VirtIODevice *vdev, uint8_t status) VHostSCSICommon *vsc = VHOST_SCSI_COMMON(s); VirtIOSCSICommon *vs = VIRTIO_SCSI_COMMON(dev); bool should_start = virtio_device_should_start(vdev, status); + Error *local_err = NULL; int ret; if (!s->connected) { @@ -84,9 +85,10 @@ static void vhost_user_scsi_set_status(VirtIODevice *vdev, uint8_t status) } if (should_start) { - ret = vhost_user_scsi_start(s); + ret = vhost_user_scsi_start(s, &local_err); if (ret < 0) { - error_report("unable to start vhost-user-scsi: %s", strerror(-ret)); + error_reportf_err(local_err, "unable to start vhost-user-scsi: %s", + strerror(-ret)); qemu_chr_fe_disconnect(&vs->conf.chardev); } } else { @@ -139,7 +141,7 @@ static void vhost_user_scsi_handle_output(VirtIODevice *vdev, VirtQueue *vq) * Some guests kick before setting VIRTIO_CONFIG_S_DRIVER_OK so start * vhost here instead of waiting for .set_status(). */ - ret = vhost_user_scsi_start(s); + ret = vhost_user_scsi_start(s, &local_err); if (ret < 0) { error_reportf_err(local_err, "vhost-user-scsi: vhost start failed: "); qemu_chr_fe_disconnect(&vs->conf.chardev); @@ -184,7 +186,7 @@ static int vhost_user_scsi_connect(DeviceState *dev, Error **errp) /* restore vhost state */ if (virtio_device_started(vdev, vdev->status)) { - ret = vhost_user_scsi_start(s); + ret = vhost_user_scsi_start(s, errp); if (ret < 0) { return ret; } diff --git a/include/hw/virtio/vhost-scsi-common.h b/include/hw/virtio/vhost-scsi-common.h index 18f115527c..c5d2c09455 100644 --- a/include/hw/virtio/vhost-scsi-common.h +++ b/include/hw/virtio/vhost-scsi-common.h @@ -39,7 +39,7 @@ struct VHostSCSICommon { struct vhost_inflight *inflight; }; -int vhost_scsi_common_start(VHostSCSICommon *vsc); +int vhost_scsi_common_start(VHostSCSICommon *vsc, Error **errp); void vhost_scsi_common_stop(VHostSCSICommon *vsc); char *vhost_scsi_common_get_fw_dev_path(FWPathProvider *p, BusState *bus, DeviceState *dev);
Add a Error parameter to report the real error, like vhost-user-blk. Signed-off-by: Li Feng <fengli@smartx.com> --- hw/scsi/vhost-scsi-common.c | 17 ++++++++++------- hw/scsi/vhost-scsi.c | 5 +++-- hw/scsi/vhost-user-scsi.c | 14 ++++++++------ include/hw/virtio/vhost-scsi-common.h | 2 +- 4 files changed, 22 insertions(+), 16 deletions(-)