backends: Plug leaks

The DRM properties container must be destroyed with
drmModeFreeObjectProperties, and the connectors must be freed on every
caller. Also make it sure that gbm_device structs are destroyed with the
MetaRendererNativeGpuData that owns them.

https://bugzilla.gnome.org/show_bug.cgi?id=789984
This commit is contained in:
Carlos Garnacho 2017-11-06 20:39:56 +01:00
parent 0a36a4545f
commit eb236649fc
3 changed files with 5 additions and 0 deletions

View File

@ -304,6 +304,8 @@ find_crtc_properties (MetaCrtc *crtc,
drmModeFreeProperty (prop); drmModeFreeProperty (prop);
} }
drmModeFreeObjectProperties (props);
} }
static void static void

View File

@ -141,6 +141,7 @@ meta_gpu_kms_apply_crtc_mode (MetaGpuKms *gpu_kms,
mode) != 0) mode) != 0)
{ {
g_warning ("Failed to set CRTC mode %s: %m", crtc->current_mode->name); g_warning ("Failed to set CRTC mode %s: %m", crtc->current_mode->name);
g_free (connectors);
return FALSE; return FALSE;
} }
@ -224,6 +225,7 @@ meta_gpu_kms_flip_crtc (MetaGpuKms *gpu_kms,
get_crtc_drm_connectors (gpu, crtc, &connectors, &n_connectors); get_crtc_drm_connectors (gpu, crtc, &connectors, &n_connectors);
g_assert (n_connectors > 0); g_assert (n_connectors > 0);
g_free (connectors);
if (!gpu_kms->page_flips_not_supported) if (!gpu_kms->page_flips_not_supported)
{ {

View File

@ -243,6 +243,7 @@ meta_renderer_native_gpu_data_free (MetaRendererNativeGpuData *renderer_gpu_data
if (renderer_gpu_data->egl_display != EGL_NO_DISPLAY) if (renderer_gpu_data->egl_display != EGL_NO_DISPLAY)
meta_egl_terminate (egl, renderer_gpu_data->egl_display, NULL); meta_egl_terminate (egl, renderer_gpu_data->egl_display, NULL);
g_clear_pointer (&renderer_gpu_data->gbm.device, gbm_device_destroy);
g_free (renderer_gpu_data); g_free (renderer_gpu_data);
} }