[Intel-gfx] [RFC 27/28] drm/i915: Compartmentalize ring buffer creation
Chris Wilson
chris at chris-wilson.co.uk
Thu Jun 13 15:46:03 UTC 2019
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).
> {
> - 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.
-Chris
More information about the Intel-gfx
mailing list