[Intel-gfx] [PATCH 27/27] drm/i915: Drop struct_mutex from around GEM initialisation
Tvrtko Ursulin
tvrtko.ursulin at linux.intel.com
Wed Sep 25 12:56:04 UTC 2019
On 25/09/2019 11:01, Chris Wilson wrote:
> We no longer need to placate lockdep by holding struct_mutex for our
> initialisation, so don't.
>
> Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> ---
> drivers/gpu/drm/i915/gem/i915_gem_pm.c | 2 --
> drivers/gpu/drm/i915/i915_gem.c | 9 ---------
> drivers/gpu/drm/i915/selftests/mock_gem_device.c | 7 -------
> 3 files changed, 18 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/gem/i915_gem_pm.c b/drivers/gpu/drm/i915/gem/i915_gem_pm.c
> index e04e4ff7b52e..d1ff854ee7ff 100644
> --- a/drivers/gpu/drm/i915/gem/i915_gem_pm.c
> +++ b/drivers/gpu/drm/i915/gem/i915_gem_pm.c
> @@ -174,7 +174,6 @@ void i915_gem_resume(struct drm_i915_private *i915)
> {
> GEM_TRACE("\n");
>
> - mutex_lock(&i915->drm.struct_mutex);
> intel_uncore_forcewake_get(&i915->uncore, FORCEWAKE_ALL);
>
> if (intel_gt_init_hw(&i915->gt))
> @@ -198,7 +197,6 @@ void i915_gem_resume(struct drm_i915_private *i915)
>
> out_unlock:
> intel_uncore_forcewake_put(&i915->uncore, FORCEWAKE_ALL);
> - mutex_unlock(&i915->drm.struct_mutex);
> return;
>
> err_wedged:
> diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
> index 8814db7023db..a5ef25b5b577 100644
> --- a/drivers/gpu/drm/i915/i915_gem.c
> +++ b/drivers/gpu/drm/i915/i915_gem.c
> @@ -1246,7 +1246,6 @@ int i915_gem_init(struct drm_i915_private *dev_priv)
> * we hold the forcewake during initialisation these problems
> * just magically go away.
> */
> - mutex_lock(&dev_priv->drm.struct_mutex);
> intel_uncore_forcewake_get(&dev_priv->uncore, FORCEWAKE_ALL);
>
> ret = i915_init_ggtt(dev_priv);
> @@ -1316,7 +1315,6 @@ int i915_gem_init(struct drm_i915_private *dev_priv)
> goto err_gt;
>
> intel_uncore_forcewake_put(&dev_priv->uncore, FORCEWAKE_ALL);
> - mutex_unlock(&dev_priv->drm.struct_mutex);
>
> return 0;
>
> @@ -1327,15 +1325,11 @@ int i915_gem_init(struct drm_i915_private *dev_priv)
> * driver doesn't explode during runtime.
> */
> err_gt:
> - mutex_unlock(&dev_priv->drm.struct_mutex);
> -
> intel_gt_set_wedged(&dev_priv->gt);
> i915_gem_suspend(dev_priv);
> i915_gem_suspend_late(dev_priv);
>
> i915_gem_drain_workqueue(dev_priv);
> -
> - mutex_lock(&dev_priv->drm.struct_mutex);
> err_init_hw:
> intel_uc_fini_hw(&dev_priv->gt.uc);
> err_uc_init:
> @@ -1350,7 +1344,6 @@ int i915_gem_init(struct drm_i915_private *dev_priv)
> intel_gt_driver_release(&dev_priv->gt);
> err_unlock:
> intel_uncore_forcewake_put(&dev_priv->uncore, FORCEWAKE_ALL);
> - mutex_unlock(&dev_priv->drm.struct_mutex);
>
> if (ret != -EIO) {
> intel_uc_cleanup_firmwares(&dev_priv->gt.uc);
> @@ -1403,10 +1396,8 @@ void i915_gem_driver_remove(struct drm_i915_private *dev_priv)
> /* Flush any outstanding unpin_work. */
> i915_gem_drain_workqueue(dev_priv);
>
> - mutex_lock(&dev_priv->drm.struct_mutex);
> intel_uc_fini_hw(&dev_priv->gt.uc);
> intel_uc_fini(&dev_priv->gt.uc);
> - mutex_unlock(&dev_priv->drm.struct_mutex);
>
> i915_gem_drain_freed_objects(dev_priv);
> }
> diff --git a/drivers/gpu/drm/i915/selftests/mock_gem_device.c b/drivers/gpu/drm/i915/selftests/mock_gem_device.c
> index 0ed21a7b8682..7950eb9825ed 100644
> --- a/drivers/gpu/drm/i915/selftests/mock_gem_device.c
> +++ b/drivers/gpu/drm/i915/selftests/mock_gem_device.c
> @@ -68,10 +68,7 @@ static void mock_device_release(struct drm_device *dev)
> drain_workqueue(i915->wq);
> i915_gem_drain_freed_objects(i915);
>
> - mutex_lock(&i915->drm.struct_mutex);
> mock_fini_ggtt(&i915->ggtt);
> - mutex_unlock(&i915->drm.struct_mutex);
> -
> destroy_workqueue(i915->wq);
>
> i915_gemfs_fini(i915);
> @@ -180,8 +177,6 @@ struct drm_i915_private *mock_gem_device(void)
>
> intel_timelines_init(i915);
>
> - mutex_lock(&i915->drm.struct_mutex);
> -
> mock_init_ggtt(i915, &i915->ggtt);
>
> mkwrite_device_info(i915)->engine_mask = BIT(0);
> @@ -198,7 +193,6 @@ struct drm_i915_private *mock_gem_device(void)
> goto err_context;
>
> intel_engines_driver_register(i915);
> - mutex_unlock(&i915->drm.struct_mutex);
>
> WARN_ON(i915_gemfs_init(i915));
>
> @@ -209,7 +203,6 @@ struct drm_i915_private *mock_gem_device(void)
> err_engine:
> mock_engine_free(i915->engine[RCS0]);
> err_unlock:
> - mutex_unlock(&i915->drm.struct_mutex);
> intel_timelines_fini(i915);
> destroy_workqueue(i915->wq);
> err_drv:
>
Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin at intel.com>
Regards,
Tvrtko
More information about the Intel-gfx
mailing list