diff options
author | Marc-André Lureau <marcandre.lureau@redhat.com> | 2023-09-15 15:28:31 +0400 |
---|---|---|
committer | Marc-André Lureau <marcandre.lureau@redhat.com> | 2023-10-03 15:09:57 +0400 |
commit | 9bd4d3df633593878ada3dffcfe05318754b4596 (patch) | |
tree | a00e7aa59555eda264120d455ece9ac886eeca1c /ui | |
parent | 75b773d84c89220463a14a6883d2b2a8e49e5b68 (diff) | |
download | qemu-9bd4d3df633593878ada3dffcfe05318754b4596.zip qemu-9bd4d3df633593878ada3dffcfe05318754b4596.tar.gz qemu-9bd4d3df633593878ada3dffcfe05318754b4596.tar.bz2 |
ui/gtk: fix UI info precondition
dpy_get_ui_info() shouldn't be called if the underlying GPU doesn't
support it.
Before the assert() was added and the regression introduced, GTK code
used to get "zero" UI info, for ex with a simple VGA device. The assert
was added to prevent from calling when there are no console too. The
other display backend that calls dpy_get_ui_info() correctly checks that
pre-condition.
Calling dpy_set_ui_info() is "safe" in this case, it will simply return
an error that can be generally ignored.
Fixes: commit a92e7bb4c ("ui: add precondition for dpy_get_ui_info()")
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Diffstat (limited to 'ui')
-rw-r--r-- | ui/gtk.c | 8 |
1 files changed, 8 insertions, 0 deletions
@@ -726,6 +726,10 @@ static void gd_set_ui_refresh_rate(VirtualConsole *vc, int refresh_rate) { QemuUIInfo info; + if (!dpy_ui_info_supported(vc->gfx.dcl.con)) { + return; + } + info = *dpy_get_ui_info(vc->gfx.dcl.con); info.refresh_rate = refresh_rate; dpy_set_ui_info(vc->gfx.dcl.con, &info, true); @@ -735,6 +739,10 @@ static void gd_set_ui_size(VirtualConsole *vc, gint width, gint height) { QemuUIInfo info; + if (!dpy_ui_info_supported(vc->gfx.dcl.con)) { + return; + } + info = *dpy_get_ui_info(vc->gfx.dcl.con); info.width = width; info.height = height; |