Revert "vhost-user: Introduce nested event loop in vhost_user_read()"
This reverts commita7f523c7d1
. The nested event loop is broken by design. It's only user was removed. Drop the code as well so that nobody ever tries to use it again. I had to fix a couple of trivial conflicts around return values because of025faa872b
("vhost-user: stick to -errno error return convention"). Signed-off-by: Greg Kurz <groug@kaod.org> Message-Id: <20230119172424.478268-3-groug@kaod.org> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Acked-by: Maxime Coquelin <maxime.coquelin@redhat.com> (cherry picked from commit4382138f64
) Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
This commit is contained in:
parent
7620c12422
commit
0c6e9547ae
@ -305,19 +305,8 @@ static int vhost_user_read_header(struct vhost_dev *dev, VhostUserMsg *msg)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct vhost_user_read_cb_data {
|
static int vhost_user_read(struct vhost_dev *dev, VhostUserMsg *msg)
|
||||||
struct vhost_dev *dev;
|
|
||||||
VhostUserMsg *msg;
|
|
||||||
GMainLoop *loop;
|
|
||||||
int ret;
|
|
||||||
};
|
|
||||||
|
|
||||||
static gboolean vhost_user_read_cb(void *do_not_use, GIOCondition condition,
|
|
||||||
gpointer opaque)
|
|
||||||
{
|
{
|
||||||
struct vhost_user_read_cb_data *data = opaque;
|
|
||||||
struct vhost_dev *dev = data->dev;
|
|
||||||
VhostUserMsg *msg = data->msg;
|
|
||||||
struct vhost_user *u = dev->opaque;
|
struct vhost_user *u = dev->opaque;
|
||||||
CharBackend *chr = u->user->chr;
|
CharBackend *chr = u->user->chr;
|
||||||
uint8_t *p = (uint8_t *) msg;
|
uint8_t *p = (uint8_t *) msg;
|
||||||
@ -325,8 +314,7 @@ static gboolean vhost_user_read_cb(void *do_not_use, GIOCondition condition,
|
|||||||
|
|
||||||
r = vhost_user_read_header(dev, msg);
|
r = vhost_user_read_header(dev, msg);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
data->ret = r;
|
return r;
|
||||||
goto end;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* validate message size is sane */
|
/* validate message size is sane */
|
||||||
@ -334,8 +322,7 @@ static gboolean vhost_user_read_cb(void *do_not_use, GIOCondition condition,
|
|||||||
error_report("Failed to read msg header."
|
error_report("Failed to read msg header."
|
||||||
" Size %d exceeds the maximum %zu.", msg->hdr.size,
|
" Size %d exceeds the maximum %zu.", msg->hdr.size,
|
||||||
VHOST_USER_PAYLOAD_SIZE);
|
VHOST_USER_PAYLOAD_SIZE);
|
||||||
data->ret = -EPROTO;
|
return -EPROTO;
|
||||||
goto end;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (msg->hdr.size) {
|
if (msg->hdr.size) {
|
||||||
@ -346,53 +333,11 @@ static gboolean vhost_user_read_cb(void *do_not_use, GIOCondition condition,
|
|||||||
int saved_errno = errno;
|
int saved_errno = errno;
|
||||||
error_report("Failed to read msg payload."
|
error_report("Failed to read msg payload."
|
||||||
" Read %d instead of %d.", r, msg->hdr.size);
|
" Read %d instead of %d.", r, msg->hdr.size);
|
||||||
data->ret = r < 0 ? -saved_errno : -EIO;
|
return r < 0 ? -saved_errno : -EIO;
|
||||||
goto end;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
end:
|
return 0;
|
||||||
g_main_loop_quit(data->loop);
|
|
||||||
return G_SOURCE_REMOVE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int vhost_user_read(struct vhost_dev *dev, VhostUserMsg *msg)
|
|
||||||
{
|
|
||||||
struct vhost_user *u = dev->opaque;
|
|
||||||
CharBackend *chr = u->user->chr;
|
|
||||||
GMainContext *prev_ctxt = chr->chr->gcontext;
|
|
||||||
GMainContext *ctxt = g_main_context_new();
|
|
||||||
GMainLoop *loop = g_main_loop_new(ctxt, FALSE);
|
|
||||||
struct vhost_user_read_cb_data data = {
|
|
||||||
.dev = dev,
|
|
||||||
.loop = loop,
|
|
||||||
.msg = msg,
|
|
||||||
.ret = 0
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
* We want to be able to monitor the slave channel fd while waiting
|
|
||||||
* for chr I/O. This requires an event loop, but we can't nest the
|
|
||||||
* one to which chr is currently attached : its fd handlers might not
|
|
||||||
* be prepared for re-entrancy. So we create a new one and switch chr
|
|
||||||
* to use it.
|
|
||||||
*/
|
|
||||||
qemu_chr_be_update_read_handlers(chr->chr, ctxt);
|
|
||||||
qemu_chr_fe_add_watch(chr, G_IO_IN | G_IO_HUP, vhost_user_read_cb, &data);
|
|
||||||
|
|
||||||
g_main_loop_run(loop);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Restore the previous event loop context. This also destroys/recreates
|
|
||||||
* event sources : this guarantees that all pending events in the original
|
|
||||||
* context that have been processed by the nested loop are purged.
|
|
||||||
*/
|
|
||||||
qemu_chr_be_update_read_handlers(chr->chr, prev_ctxt);
|
|
||||||
|
|
||||||
g_main_loop_unref(loop);
|
|
||||||
g_main_context_unref(ctxt);
|
|
||||||
|
|
||||||
return data.ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int process_message_reply(struct vhost_dev *dev,
|
static int process_message_reply(struct vhost_dev *dev,
|
||||||
|
Loading…
Reference in New Issue
Block a user