[libvirt] [PATCH] qemu: Don't fail qemuProcessAttach for IOThreads if no JSON
Daniel P. Berrange
berrange at redhat.com
Thu Sep 18 10:22:41 UTC 2014
On Thu, Sep 18, 2014 at 06:18:22AM -0400, John Ferlan wrote:
>
>
> On 09/18/2014 04:39 AM, Daniel P. Berrange wrote:
> > On Wed, Sep 17, 2014 at 03:07:47PM -0400, John Ferlan wrote:
> >> While doing some investigation for another bug I found that I could
> >> not qemu-attach to the process and got the following:
> >>
> >> error: Operation not supported: JSON monitor is required
> >>
> >> while running thru qemuProcessAttach. Since we can only get the data
> >> using the JSON parser and if the guest to be attached to doesn't have
> >> it we shouldn't just fail. See example in virsh qemu-attach for sample
> >> command that failed.
> >
> > It isn't simply qemu-attach that's affected. If you merely try to
> > start a guest normally with a QEMU that predates JSON support this
> > would fail too.
> >
> >> Signed-off-by: John Ferlan <jferlan at redhat.com>
> >> ---
> >>
> >> I also considered removing the call from qemuProcessAttach rather than
> >> this approach.
> >>
> >> src/qemu/qemu_monitor.c | 8 +++-----
> >> 1 file changed, 3 insertions(+), 5 deletions(-)
> >>
> >> diff --git a/src/qemu/qemu_monitor.c b/src/qemu/qemu_monitor.c
> >> index 8927dbb..4342088 100644
> >> --- a/src/qemu/qemu_monitor.c
> >> +++ b/src/qemu/qemu_monitor.c
> >> @@ -4112,11 +4112,9 @@ qemuMonitorGetIOThreads(qemuMonitorPtr mon,
> >> return -1;
> >> }
> >>
> >> - if (!mon->json) {
> >> - virReportError(VIR_ERR_OPERATION_UNSUPPORTED, "%s",
> >> - _("JSON monitor is required"));
> >> - return -1;
> >> - }
> >> + /* Requires JSON to make the query */
> >> + if (!mon->json)
> >> + return 0;
> >
> > I think you need should do '*iothreads = NULL' for safety too.
> >
>
> OK with the following squashed in?
>
> diff --git a/src/qemu/qemu_monitor.c b/src/qemu/qemu_monitor.c
> index 4342088..10f51c5 100644
> --- a/src/qemu/qemu_monitor.c
> +++ b/src/qemu/qemu_monitor.c
> @@ -4113,8 +4113,10 @@ qemuMonitorGetIOThreads(qemuMonitorPtr mon,
> }
>
> /* Requires JSON to make the query */
> - if (!mon->json)
> + if (!mon->json) {
> + *iothreads = NULL;
> return 0;
> + }
>
> return qemuMonitorJSONGetIOThreads(mon, iothreads);
> }
ACK
Regards,
Daniel
--
|: http://berrange.com -o- http://www.flickr.com/photos/dberrange/ :|
|: http://libvirt.org -o- http://virt-manager.org :|
|: http://autobuild.org -o- http://search.cpan.org/~danberr/ :|
|: http://entangle-photo.org -o- http://live.gnome.org/gtk-vnc :|
More information about the libvir-list
mailing list