[Intel-gfx] [PATCH] drm/i915: unbind fbs from crtcs during driver unload

Daniel Vetter daniel at ffwll.ch
Tue Feb 11 23:12:07 CET 2014


On Wed, Feb 12, 2014 at 12:01:10AM +0200, Imre Deak wrote:
> So far during driver unload we called drm_framebuffer_cleanup() for the
> fbdev fb, which only removes the fb from the drm fb list regardless of
> its reference count, but leaves the fb bound on an active crtc. Since
> the fb's backing storage was freed this could mean we scan some random
> memory content out afterwards. It's not a big issue since the fb is
> allocated from stolen memory and afaik there is no other user for that
> than i915. It's still cleaner to properly unbind the fb and disable the
> crtc, which is what drm_framebuffer_remove() does.
> 
> Note that after
> 
> commit 88891eb1e9eca0ba619518bed31580f91e9cf84d
> Author: Daniel Vetter <daniel.vetter at ffwll.ch>
> Date:   Mon Feb 10 18:00:38 2014 +0100
> 
> we call drm_framebuffer_cleanup() only after dropping the last reference
> on the fb, but that won't happen since we don't unbind the fb. This
> results in a drm core warn about a leaked fb.
> 
> Signed-off-by: Imre Deak <imre.deak at intel.com>

Yeah, makes more sense. Apparently I really don't know my own fb lifetime
rules :( Queued for -next, thanks for the patch.
-Daniel

> ---
>  drivers/gpu/drm/i915/intel_fbdev.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/drivers/gpu/drm/i915/intel_fbdev.c b/drivers/gpu/drm/i915/intel_fbdev.c
> index cf46273..3a53ee3 100644
> --- a/drivers/gpu/drm/i915/intel_fbdev.c
> +++ b/drivers/gpu/drm/i915/intel_fbdev.c
> @@ -265,7 +265,7 @@ static void intel_fbdev_destroy(struct drm_device *dev,
>  	drm_fb_helper_fini(&ifbdev->helper);
>  
>  	drm_framebuffer_unregister_private(&ifbdev->fb->base);
> -	drm_framebuffer_unreference(&ifbdev->fb->base);
> +	drm_framebuffer_remove(&ifbdev->fb->base);
>  }
>  
>  int intel_fbdev_init(struct drm_device *dev)
> -- 
> 1.8.3.2
> 
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/intel-gfx

-- 
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch



More information about the Intel-gfx mailing list