[virt-tools-list] [PATCH virt-viewer] Fix segmentation fault on zoom

Fabiano Fidêncio fidencio at redhat.com
Tue Jun 7 20:38:44 UTC 2016


Charles.

On Tue, Jun 7, 2016 at 9:51 PM, Charles Arnold <carnold at suse.com> wrote:
> When virt-viewer is "Waiting for guest domain to start" and
> the Ctrl- or Ctrl+ keys are pressed to zoom the blank display
> virt-viewer will crash in virt_viewer_display_get_desktop_size
> because of a NULL display pointer. To reproduce start virt-viewer
> on a VM not running and zoom the display.

Nice catch!

>
> Signed-off-by: Charles Arnold <carnold at suse.com>
>
> diff --git a/src/virt-viewer-window.c b/src/virt-viewer-window.c
> index ef62d9a..939f5f8 100644
> --- a/src/virt-viewer-window.c
> +++ b/src/virt-viewer-window.c
> @@ -388,6 +388,9 @@ G_MODULE_EXPORT void
>  virt_viewer_window_menu_view_zoom_out(GtkWidget *menu G_GNUC_UNUSED,
>                                        VirtViewerWindow *self)
>  {
> +    if ( self->priv->display == NULL )
> +        return;
> +
>      virt_viewer_window_set_zoom_level(self,
>                                        virt_viewer_window_get_real_zoom_level(self) - ZOOM_STEP);
>  }
> @@ -396,6 +399,9 @@ G_MODULE_EXPORT void
>  virt_viewer_window_menu_view_zoom_in(GtkWidget *menu G_GNUC_UNUSED,
>                                       VirtViewerWindow *self)
>  {
> +    if ( self->priv->display == NULL )
> +        return;
> +
>      virt_viewer_window_set_zoom_level(self,
>                                        virt_viewer_window_get_real_zoom_level(self) + ZOOM_STEP);
>  }
>
>
>
> _______________________________________________
> virt-tools-list mailing list
> virt-tools-list at redhat.com
> https://www.redhat.com/mailman/listinfo/virt-tools-list

I'd prefer to have the check done on
virt_viewer_window_get_real_zoom_level(), like the example below. What
do you think? If you agree I'll do the change before pushing and keep
your ownership of the patch.

[ffidenci at cat virt-viewer]$ git diff
diff --git a/src/virt-viewer-window.c b/src/virt-viewer-window.c
index ef62d9a..38effab 100644
--- a/src/virt-viewer-window.c
+++ b/src/virt-viewer-window.c
@@ -378,6 +378,9 @@
virt_viewer_window_get_real_zoom_level(VirtViewerWindow *self)
     GtkAllocation allocation;
     guint width, height;

+    if (self->priv->display == NULL)
+        return 0;
+
     gtk_widget_get_allocation(GTK_WIDGET(self->priv->display), &allocation);
     virt_viewer_display_get_desktop_size(self->priv->display, &width, &height);

Best Regards,
--
Fabiano Fidêncio




More information about the virt-tools-list mailing list