提交 c6be607a 编写于 作者: T Tvrtko Ursulin

drm/i915: dev_priv and a small cascade of cleanups in i915_gem.c

Signed-off-by: NTvrtko Ursulin <tvrtko.ursulin@intel.com>
Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
上级 d15d47ac
...@@ -2426,7 +2426,7 @@ static int intel_runtime_resume(struct device *kdev) ...@@ -2426,7 +2426,7 @@ static int intel_runtime_resume(struct device *kdev)
* No point of rolling back things in case of an error, as the best * No point of rolling back things in case of an error, as the best
* we can do is to hope that things will still work (and disable RPM). * we can do is to hope that things will still work (and disable RPM).
*/ */
i915_gem_init_swizzling(dev); i915_gem_init_swizzling(dev_priv);
intel_runtime_pm_enable_interrupts(dev_priv); intel_runtime_pm_enable_interrupts(dev_priv);
......
...@@ -3095,7 +3095,7 @@ void i915_gem_set_wedged(struct drm_i915_private *dev_priv); ...@@ -3095,7 +3095,7 @@ void i915_gem_set_wedged(struct drm_i915_private *dev_priv);
void i915_gem_clflush_object(struct drm_i915_gem_object *obj, bool force); void i915_gem_clflush_object(struct drm_i915_gem_object *obj, bool force);
int __must_check i915_gem_init(struct drm_device *dev); int __must_check i915_gem_init(struct drm_device *dev);
int __must_check i915_gem_init_hw(struct drm_device *dev); int __must_check i915_gem_init_hw(struct drm_device *dev);
void i915_gem_init_swizzling(struct drm_device *dev); void i915_gem_init_swizzling(struct drm_i915_private *dev_priv);
void i915_gem_cleanup_engines(struct drm_device *dev); void i915_gem_cleanup_engines(struct drm_device *dev);
int __must_check i915_gem_wait_for_idle(struct drm_i915_private *dev_priv, int __must_check i915_gem_wait_for_idle(struct drm_i915_private *dev_priv,
unsigned int flags); unsigned int flags);
......
...@@ -4241,11 +4241,9 @@ void i915_gem_resume(struct drm_device *dev) ...@@ -4241,11 +4241,9 @@ void i915_gem_resume(struct drm_device *dev)
mutex_unlock(&dev->struct_mutex); mutex_unlock(&dev->struct_mutex);
} }
void i915_gem_init_swizzling(struct drm_device *dev) void i915_gem_init_swizzling(struct drm_i915_private *dev_priv)
{ {
struct drm_i915_private *dev_priv = to_i915(dev); if (INTEL_GEN(dev_priv) < 5 ||
if (INTEL_INFO(dev)->gen < 5 ||
dev_priv->mm.bit_6_swizzle_x == I915_BIT_6_SWIZZLE_NONE) dev_priv->mm.bit_6_swizzle_x == I915_BIT_6_SWIZZLE_NONE)
return; return;
...@@ -4316,14 +4314,14 @@ i915_gem_init_hw(struct drm_device *dev) ...@@ -4316,14 +4314,14 @@ i915_gem_init_hw(struct drm_device *dev)
u32 temp = I915_READ(GEN7_MSG_CTL); u32 temp = I915_READ(GEN7_MSG_CTL);
temp &= ~(WAIT_FOR_PCH_FLR_ACK | WAIT_FOR_PCH_RESET_ACK); temp &= ~(WAIT_FOR_PCH_FLR_ACK | WAIT_FOR_PCH_RESET_ACK);
I915_WRITE(GEN7_MSG_CTL, temp); I915_WRITE(GEN7_MSG_CTL, temp);
} else if (INTEL_INFO(dev)->gen >= 7) { } else if (INTEL_GEN(dev_priv) >= 7) {
u32 temp = I915_READ(HSW_NDE_RSTWRN_OPT); u32 temp = I915_READ(HSW_NDE_RSTWRN_OPT);
temp &= ~RESET_PCH_HANDSHAKE_ENABLE; temp &= ~RESET_PCH_HANDSHAKE_ENABLE;
I915_WRITE(HSW_NDE_RSTWRN_OPT, temp); I915_WRITE(HSW_NDE_RSTWRN_OPT, temp);
} }
} }
i915_gem_init_swizzling(dev); i915_gem_init_swizzling(dev_priv);
/* /*
* At least 830 can leave some of the unused rings * At least 830 can leave some of the unused rings
...@@ -4335,7 +4333,7 @@ i915_gem_init_hw(struct drm_device *dev) ...@@ -4335,7 +4333,7 @@ i915_gem_init_hw(struct drm_device *dev)
BUG_ON(!dev_priv->kernel_context); BUG_ON(!dev_priv->kernel_context);
ret = i915_ppgtt_init_hw(dev); ret = i915_ppgtt_init_hw(dev_priv);
if (ret) { if (ret) {
DRM_ERROR("PPGTT enable HW failed %d\n", ret); DRM_ERROR("PPGTT enable HW failed %d\n", ret);
goto out; goto out;
......
...@@ -1794,22 +1794,21 @@ static int gen6_mm_switch(struct i915_hw_ppgtt *ppgtt, ...@@ -1794,22 +1794,21 @@ static int gen6_mm_switch(struct i915_hw_ppgtt *ppgtt,
return 0; return 0;
} }
static void gen8_ppgtt_enable(struct drm_device *dev) static void gen8_ppgtt_enable(struct drm_i915_private *dev_priv)
{ {
struct drm_i915_private *dev_priv = to_i915(dev);
struct intel_engine_cs *engine; struct intel_engine_cs *engine;
enum intel_engine_id id; enum intel_engine_id id;
for_each_engine(engine, dev_priv, id) { for_each_engine(engine, dev_priv, id) {
u32 four_level = USES_FULL_48BIT_PPGTT(dev) ? GEN8_GFX_PPGTT_48B : 0; u32 four_level = USES_FULL_48BIT_PPGTT(dev_priv) ?
GEN8_GFX_PPGTT_48B : 0;
I915_WRITE(RING_MODE_GEN7(engine), I915_WRITE(RING_MODE_GEN7(engine),
_MASKED_BIT_ENABLE(GFX_PPGTT_ENABLE | four_level)); _MASKED_BIT_ENABLE(GFX_PPGTT_ENABLE | four_level));
} }
} }
static void gen7_ppgtt_enable(struct drm_device *dev) static void gen7_ppgtt_enable(struct drm_i915_private *dev_priv)
{ {
struct drm_i915_private *dev_priv = to_i915(dev);
struct intel_engine_cs *engine; struct intel_engine_cs *engine;
uint32_t ecochk, ecobits; uint32_t ecochk, ecobits;
enum intel_engine_id id; enum intel_engine_id id;
...@@ -1833,9 +1832,8 @@ static void gen7_ppgtt_enable(struct drm_device *dev) ...@@ -1833,9 +1832,8 @@ static void gen7_ppgtt_enable(struct drm_device *dev)
} }
} }
static void gen6_ppgtt_enable(struct drm_device *dev) static void gen6_ppgtt_enable(struct drm_i915_private *dev_priv)
{ {
struct drm_i915_private *dev_priv = to_i915(dev);
uint32_t ecochk, gab_ctl, ecobits; uint32_t ecochk, gab_ctl, ecobits;
ecobits = I915_READ(GAC_ECO_BITS); ecobits = I915_READ(GAC_ECO_BITS);
...@@ -2193,10 +2191,8 @@ static void i915_address_space_init(struct i915_address_space *vm, ...@@ -2193,10 +2191,8 @@ static void i915_address_space_init(struct i915_address_space *vm,
list_add_tail(&vm->global_link, &dev_priv->vm_list); list_add_tail(&vm->global_link, &dev_priv->vm_list);
} }
static void gtt_write_workarounds(struct drm_device *dev) static void gtt_write_workarounds(struct drm_i915_private *dev_priv)
{ {
struct drm_i915_private *dev_priv = to_i915(dev);
/* This function is for gtt related workarounds. This function is /* This function is for gtt related workarounds. This function is
* called on driver load and after a GPU reset, so you can place * called on driver load and after a GPU reset, so you can place
* workarounds here even if they get overwritten by GPU reset. * workarounds here even if they get overwritten by GPU reset.
...@@ -2229,11 +2225,9 @@ static int i915_ppgtt_init(struct i915_hw_ppgtt *ppgtt, ...@@ -2229,11 +2225,9 @@ static int i915_ppgtt_init(struct i915_hw_ppgtt *ppgtt,
return ret; return ret;
} }
int i915_ppgtt_init_hw(struct drm_device *dev) int i915_ppgtt_init_hw(struct drm_i915_private *dev_priv)
{ {
struct drm_i915_private *dev_priv = to_i915(dev); gtt_write_workarounds(dev_priv);
gtt_write_workarounds(dev);
/* In the case of execlists, PPGTT is enabled by the context descriptor /* In the case of execlists, PPGTT is enabled by the context descriptor
* and the PDPs are contained within the context itself. We don't * and the PDPs are contained within the context itself. We don't
...@@ -2241,17 +2235,17 @@ int i915_ppgtt_init_hw(struct drm_device *dev) ...@@ -2241,17 +2235,17 @@ int i915_ppgtt_init_hw(struct drm_device *dev)
if (i915.enable_execlists) if (i915.enable_execlists)
return 0; return 0;
if (!USES_PPGTT(dev)) if (!USES_PPGTT(dev_priv))
return 0; return 0;
if (IS_GEN6(dev_priv)) if (IS_GEN6(dev_priv))
gen6_ppgtt_enable(dev); gen6_ppgtt_enable(dev_priv);
else if (IS_GEN7(dev_priv)) else if (IS_GEN7(dev_priv))
gen7_ppgtt_enable(dev); gen7_ppgtt_enable(dev_priv);
else if (INTEL_INFO(dev)->gen >= 8) else if (INTEL_GEN(dev_priv) >= 8)
gen8_ppgtt_enable(dev); gen8_ppgtt_enable(dev_priv);
else else
MISSING_CASE(INTEL_INFO(dev)->gen); MISSING_CASE(INTEL_GEN(dev_priv));
return 0; return 0;
} }
......
...@@ -495,7 +495,7 @@ int i915_ggtt_enable_hw(struct drm_i915_private *dev_priv); ...@@ -495,7 +495,7 @@ int i915_ggtt_enable_hw(struct drm_i915_private *dev_priv);
int i915_gem_init_ggtt(struct drm_i915_private *dev_priv); int i915_gem_init_ggtt(struct drm_i915_private *dev_priv);
void i915_ggtt_cleanup_hw(struct drm_i915_private *dev_priv); void i915_ggtt_cleanup_hw(struct drm_i915_private *dev_priv);
int i915_ppgtt_init_hw(struct drm_device *dev); int i915_ppgtt_init_hw(struct drm_i915_private *dev_priv);
void i915_ppgtt_release(struct kref *kref); void i915_ppgtt_release(struct kref *kref);
struct i915_hw_ppgtt *i915_ppgtt_create(struct drm_i915_private *dev_priv, struct i915_hw_ppgtt *i915_ppgtt_create(struct drm_i915_private *dev_priv,
struct drm_i915_file_private *fpriv, struct drm_i915_file_private *fpriv,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册