[Intel-gfx] [PATCH] drm/i915: Only unlink ggtt->global_link after i915_gem_load

Ben Widawsky ben at bwidawsk.net
Fri Jan 10 21:22:44 CET 2014


On Mon, Dec 16, 2013 at 06:58:20PM +0000, Chris Wilson wrote:
> On Mon, Dec 16, 2013 at 12:01:07PM +0000, Chris Wilson wrote:
> > If i915_driver_load fails before i915_gem_load we try to unlink the ggtt
> > prior to initialising the list and triggering an oops.
> 
> This is incomplete.
>  
> > Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> > ---
> >  drivers/gpu/drm/i915/i915_dma.c | 2 +-
> >  1 file changed, 1 insertion(+), 1 deletion(-)
> > 
> > diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c
> > index df1410ecbb8b..6364c503f97d 100644
> > --- a/drivers/gpu/drm/i915/i915_dma.c
> > +++ b/drivers/gpu/drm/i915/i915_dma.c
> > @@ -1683,11 +1683,11 @@ out_gem_unload:
> >  	intel_teardown_gmbus(dev);
> >  	intel_teardown_mchbar(dev);
> >  	destroy_workqueue(dev_priv->wq);
> > +	list_del(&dev_priv->gtt.base.global_link);

This is correct.

> +	dev_priv->gtt.base.cleanup(&dev_priv->gtt.base);

I'm not convinced here. It should be safe [ideal] to call cleanup after
we've setup the function pointer, which would be out_gtt; it's done in
i915_gem_gtt_init(). If it's not safe to call for some reason, we should
fix cleanup()

> >  out_mtrrfree:
> >  	arch_phys_wc_del(dev_priv->gtt.mtrr);
> >  	io_mapping_free(dev_priv->gtt.mappable);
> >  out_gtt:
> > -	list_del(&dev_priv->gtt.base.global_link);
> -  	drm_mm_takedown(&dev_priv->gtt.base.mm);

This is correct.

> -  	dev_priv->gtt.base.cleanup(&dev_priv->gtt.base);
> 
> -- 
> Chris Wilson, Intel Open Source Technology Centre

-- 
Ben Widawsky, Intel Open Source Technology Center



More information about the Intel-gfx mailing list