提交 90638cc1 编写于 作者: J John Harrison 提交者: Daniel Vetter

drm/i915: Moved the for_each_ring loop outside of i915_gem_context_enable()

The start of day context initialisation code in i915_gem_context_enable() loops
over each ring and calls the legacy switch context or the execlist init context
code as appropriate.

This patch moves the ring looping out of that function in to the top level
caller i915_gem_init_hw(). This means the a single pass can be made over all
rings doing the PPGTT, L3 remap and context initialisation of each ring
altogether.

For: VIZ-5115
Signed-off-by: NJohn Harrison <John.C.Harrison@Intel.com>
Reviewed-by: NTomas Elf <tomas.elf@intel.com>
Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
上级 4ad2fd88
...@@ -3039,7 +3039,7 @@ int __must_check i915_gem_context_init(struct drm_device *dev); ...@@ -3039,7 +3039,7 @@ int __must_check i915_gem_context_init(struct drm_device *dev);
void i915_gem_context_fini(struct drm_device *dev); void i915_gem_context_fini(struct drm_device *dev);
void i915_gem_context_reset(struct drm_device *dev); void i915_gem_context_reset(struct drm_device *dev);
int i915_gem_context_open(struct drm_device *dev, struct drm_file *file); int i915_gem_context_open(struct drm_device *dev, struct drm_file *file);
int i915_gem_context_enable(struct drm_i915_private *dev_priv); int i915_gem_context_enable(struct intel_engine_cs *ring);
void i915_gem_context_close(struct drm_device *dev, struct drm_file *file); void i915_gem_context_close(struct drm_device *dev, struct drm_file *file);
int i915_switch_context(struct intel_engine_cs *ring, int i915_switch_context(struct intel_engine_cs *ring,
struct intel_context *to); struct intel_context *to);
......
...@@ -5052,6 +5052,8 @@ i915_gem_init_hw(struct drm_device *dev) ...@@ -5052,6 +5052,8 @@ i915_gem_init_hw(struct drm_device *dev)
*/ */
init_unused_rings(dev); init_unused_rings(dev);
BUG_ON(!dev_priv->ring[RCS].default_context);
ret = i915_ppgtt_init_hw(dev); ret = i915_ppgtt_init_hw(dev);
if (ret) { if (ret) {
DRM_ERROR("PPGTT enable HW failed %d\n", ret); DRM_ERROR("PPGTT enable HW failed %d\n", ret);
...@@ -5067,6 +5069,8 @@ i915_gem_init_hw(struct drm_device *dev) ...@@ -5067,6 +5069,8 @@ i915_gem_init_hw(struct drm_device *dev)
/* Now it is safe to go back round and do everything else: */ /* Now it is safe to go back round and do everything else: */
for_each_ring(ring, dev_priv, i) { for_each_ring(ring, dev_priv, i) {
WARN_ON(!ring->default_context);
if (ring->id == RCS) { if (ring->id == RCS) {
for (j = 0; j < NUM_L3_SLICES(dev); j++) for (j = 0; j < NUM_L3_SLICES(dev); j++)
i915_gem_l3_remap(ring, j); i915_gem_l3_remap(ring, j);
...@@ -5078,14 +5082,13 @@ i915_gem_init_hw(struct drm_device *dev) ...@@ -5078,14 +5082,13 @@ i915_gem_init_hw(struct drm_device *dev)
i915_gem_cleanup_ringbuffer(dev); i915_gem_cleanup_ringbuffer(dev);
goto out; goto out;
} }
}
ret = i915_gem_context_enable(dev_priv); ret = i915_gem_context_enable(ring);
if (ret && ret != -EIO) { if (ret && ret != -EIO) {
DRM_ERROR("Context enable failed %d\n", ret); DRM_ERROR("Context enable ring #%d failed %d\n", i, ret);
i915_gem_cleanup_ringbuffer(dev); i915_gem_cleanup_ringbuffer(dev);
goto out;
goto out; }
} }
out: out:
......
...@@ -409,32 +409,22 @@ void i915_gem_context_fini(struct drm_device *dev) ...@@ -409,32 +409,22 @@ void i915_gem_context_fini(struct drm_device *dev)
i915_gem_context_unreference(dctx); i915_gem_context_unreference(dctx);
} }
int i915_gem_context_enable(struct drm_i915_private *dev_priv) int i915_gem_context_enable(struct intel_engine_cs *ring)
{ {
struct intel_engine_cs *ring; int ret;
int ret, i;
BUG_ON(!dev_priv->ring[RCS].default_context);
if (i915.enable_execlists) { if (i915.enable_execlists) {
for_each_ring(ring, dev_priv, i) { if (ring->init_context == NULL)
if (ring->init_context) { return 0;
ret = ring->init_context(ring,
ring->default_context);
if (ret) {
DRM_ERROR("ring init context: %d\n",
ret);
return ret;
}
}
}
ret = ring->init_context(ring, ring->default_context);
} else } else
for_each_ring(ring, dev_priv, i) { ret = i915_switch_context(ring, ring->default_context);
ret = i915_switch_context(ring, ring->default_context);
if (ret) if (ret) {
return ret; DRM_ERROR("ring init context: %d\n", ret);
} return ret;
}
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册