[Intel-gfx] [RFC 27/28] drm/i915: Compartmentalize ring buffer creation
Tvrtko Ursulin
tvrtko.ursulin at linux.intel.com
Thu Jun 13 15:56:37 UTC 2019
On 13/06/2019 16:46, Chris Wilson wrote:
> Quoting Tvrtko Ursulin (2019-06-13 16:19:03)
>> From: Tvrtko Ursulin <tvrtko.ursulin at intel.com>
>>
>> Continuing on the theme of compartmentalizing the code better to make
>> future split between gt and display in global i915 clearer.
>>
>> Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin at intel.com>
>> ---
>> drivers/gpu/drm/i915/gt/intel_ringbuffer.c | 17 +++++++++--------
>> 1 file changed, 9 insertions(+), 8 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/i915/gt/intel_ringbuffer.c b/drivers/gpu/drm/i915/gt/intel_ringbuffer.c
>> index b3bf47e8162f..0a1d952ad160 100644
>> --- a/drivers/gpu/drm/i915/gt/intel_ringbuffer.c
>> +++ b/drivers/gpu/drm/i915/gt/intel_ringbuffer.c
>> @@ -1226,16 +1226,16 @@ void intel_ring_unpin(struct intel_ring *ring)
>> i915_timeline_unpin(ring->timeline);
>> }
>>
>> -static struct i915_vma *
>> -intel_ring_create_vma(struct drm_i915_private *dev_priv, int size)
>> +static struct i915_vma *create_ring_vma(struct intel_gt *gt, int size)
>
> Here, it probably makes more sense to be passing i915_ggtt (since this
> is about the i915_vma itself).
Yep, good point.
>> {
>> - struct i915_address_space *vm = &dev_priv->ggtt.vm;
>> + struct i915_address_space *vm = >->ggtt->vm;
>> + struct drm_i915_private *i915 = gt->i915;
>> struct drm_i915_gem_object *obj;
>> struct i915_vma *vma;
>>
>> - obj = i915_gem_object_create_stolen(dev_priv, size);
>> + obj = i915_gem_object_create_stolen(i915, size);
>> if (!obj)
>> - obj = i915_gem_object_create_internal(dev_priv, size);
>> + obj = i915_gem_object_create_internal(i915, size);
>> if (IS_ERR(obj))
>> return ERR_CAST(obj);
>>
>> @@ -1262,13 +1262,14 @@ intel_engine_create_ring(struct intel_engine_cs *engine,
>> struct i915_timeline *timeline,
>> int size)
>> {
>> + struct drm_i915_private *i915 = engine->i915;
>> struct intel_ring *ring;
>> struct i915_vma *vma;
>>
>> GEM_BUG_ON(!is_power_of_2(size));
>> GEM_BUG_ON(RING_CTL_SIZE(size) & ~RING_NR_PAGES);
>> GEM_BUG_ON(timeline == &engine->timeline);
>> - lockdep_assert_held(&engine->i915->drm.struct_mutex);
>> + lockdep_assert_held(&i915->drm.struct_mutex);
>
> Heresy.
What why?
Regards,
Tvrtko
More information about the Intel-gfx
mailing list