[Intel-gfx] [PATCH] drm/i915: Defer adding preallocated stolen objects to the VM list
Jani Nikula
jani.nikula at linux.intel.com
Thu Sep 24 04:24:36 PDT 2015
On Thu, 24 Sep 2015, "Winiarski, Michal" <michal.winiarski at intel.com> wrote:
> On Thu, 2015-09-24 at 11:57 +0100, Chris Wilson wrote:
>> When preallocating a stolen object during early initialisation, we
>> may
>> be running before we have setup the the global GTT VM state, in
>> particular before we have initialised the range manager and
>> associated
>> lists. As this is the case, we defer binding the stolen object until
>> we
>> call i915_gem_setup_global_gtt(). Not only should we defer the
>> binding,
>> but we should also defer the VM list manipulation.
>>
>> Fixes regression uncovered by commit
>> a2cad9dff4dd44d0244b966d980de9d602d87593
>> Author: Michał Winiarski <michal.winiarski at intel.com>
>> Date: Wed Sep 16 11:49:00 2015 +0200
>>
>> drm/i915/gtt: Do not initialize drm_mm twice.
I confirm reverting the above works.
This patch is
Tested-by: Jani Nikula <jani.nikula at intel.com>
on a BWD GT2 ULT.
>>
>> Whilst I am here remove the duplicate work leaving dangling pointers
>> from the error path...
>>
>> v2: Typos galore before coffee.
>>
>> Reported-by: Jesse Barnes <jbarnes at virtuousgeek.org>
>> Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=92099
>> Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
>> Cc: Jesse Barnes <jbarnes at virtuousgeek.org>
>> Cc: Michel Thierry <michel.thierry at intel.com>
>> Cc: Mika Kuoppala <mika.kuoppala at intel.com>
>> Cc: Michał Winiarski <michal.winiarski at intel.com>
>> Cc: Daniel Vetter <daniel.vetter at ffwll.ch>
>> Cc: Jani Nikula <jani.nikula at linux.intel.com>
>
> Reviewed-by: Michał Winiarski <michal.winiarski at intel.com>
>
> -Michał
>
>> ---
>> drivers/gpu/drm/i915/i915_gem_gtt.c | 2 +-
>> drivers/gpu/drm/i915/i915_gem_stolen.c | 16 ++++++----------
>> 2 files changed, 7 insertions(+), 11 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/i915/i915_gem_gtt.c
>> b/drivers/gpu/drm/i915/i915_gem_gtt.c
>> index 01f3521e77d3..291305fb2f3c 100644
>> --- a/drivers/gpu/drm/i915/i915_gem_gtt.c
>> +++ b/drivers/gpu/drm/i915/i915_gem_gtt.c
>> @@ -2533,7 +2533,6 @@ static int ggtt_bind_vma(struct i915_vma *vma,
>> * the bound flag ourselves.
>> */
>> vma->bound |= GLOBAL_BIND;
>> -
>> }
>>
>> if (dev_priv->mm.aliasing_ppgtt && flags & LOCAL_BIND) {
>> @@ -2657,6 +2656,7 @@ static int i915_gem_setup_global_gtt(struct
>> drm_device *dev,
>> return ret;
>> }
>> vma->bound |= GLOBAL_BIND;
>> + list_add_tail(&vma->mm_list, &ggtt_vm
>> ->inactive_list);
>> }
>>
>> /* Clear any non-preallocated blocks */
>> diff --git a/drivers/gpu/drm/i915/i915_gem_stolen.c
>> b/drivers/gpu/drm/i915/i915_gem_stolen.c
>> index 55df6ce34751..15207796e1b3 100644
>> --- a/drivers/gpu/drm/i915/i915_gem_stolen.c
>> +++ b/drivers/gpu/drm/i915/i915_gem_stolen.c
>> @@ -584,7 +584,7 @@
>> i915_gem_object_create_stolen_for_preallocated(struct drm_device
>> *dev,
>> vma = i915_gem_obj_lookup_or_create_vma(obj, ggtt);
>> if (IS_ERR(vma)) {
>> ret = PTR_ERR(vma);
>> - goto err_out;
>> + goto err;
>> }
>>
>> /* To simplify the initialisation sequence between KMS and
>> GTT,
>> @@ -598,23 +598,19 @@
>> i915_gem_object_create_stolen_for_preallocated(struct drm_device
>> *dev,
>> ret = drm_mm_reserve_node(&ggtt->mm, &vma->node);
>> if (ret) {
>> DRM_DEBUG_KMS("failed to allocate stolen GTT
>> space\n");
>> - goto err_vma;
>> + goto err;
>> }
>> - }
>>
>> - vma->bound |= GLOBAL_BIND;
>> + vma->bound |= GLOBAL_BIND;
>> + list_add_tail(&vma->mm_list, &ggtt->inactive_list);
>> + }
>>
>> list_add_tail(&obj->global_list, &dev_priv->mm.bound_list);
>> - list_add_tail(&vma->mm_list, &ggtt->inactive_list);
>> i915_gem_object_pin_pages(obj);
>>
>> return obj;
>>
>> -err_vma:
>> - i915_gem_vma_destroy(vma);
>> -err_out:
>> - i915_gem_stolen_remove_node(dev_priv, stolen);
>> - kfree(stolen);
>> +err:
>> drm_gem_object_unreference(&obj->base);
>> return NULL;
>> }
--
Jani Nikula, Intel Open Source Technology Center
More information about the Intel-gfx
mailing list