chardev: add Chardev.gcontext field
It caches the gcontext that is used to poll the chardev IO. Before this patch, we only passed it in via chr_update_read_handlers(). However that may not be enough if the char backend is disconnected and reconnected afterward. There are chardev codes that still assumed the context be NULL (which is the main context). Will fix that up in following up patches. Signed-off-by: Peter Xu <peterx@redhat.com> Message-Id: <1505975754-21555-3-git-send-email-peterx@redhat.com> Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
07241c205c
commit
95eeeba669
@ -185,6 +185,7 @@ void qemu_chr_be_update_read_handlers(Chardev *s,
|
|||||||
{
|
{
|
||||||
ChardevClass *cc = CHARDEV_GET_CLASS(s);
|
ChardevClass *cc = CHARDEV_GET_CLASS(s);
|
||||||
|
|
||||||
|
s->gcontext = context;
|
||||||
if (cc->chr_update_read_handler) {
|
if (cc->chr_update_read_handler) {
|
||||||
cc->chr_update_read_handler(s, context);
|
cc->chr_update_read_handler(s, context);
|
||||||
}
|
}
|
||||||
|
@ -55,6 +55,7 @@ struct Chardev {
|
|||||||
int logfd;
|
int logfd;
|
||||||
int be_open;
|
int be_open;
|
||||||
GSource *gsource;
|
GSource *gsource;
|
||||||
|
GMainContext *gcontext;
|
||||||
DECLARE_BITMAP(features, QEMU_CHAR_FEATURE_LAST);
|
DECLARE_BITMAP(features, QEMU_CHAR_FEATURE_LAST);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user