Commit 77a302e0 authored by Tvrtko Ursulin's avatar Tvrtko Ursulin

drm/i915: Make Gen6/7 RING_FAULT_REG access engine centric

Similar to earlier conversions, eliminate the implicit dev_priv by
introducing some helpers which take the engine parameter (since the
register itself is per engine).

v2:
 * Always use parentheses in macro arguments.
Signed-off-by: default avatarTvrtko Ursulin <tvrtko.ursulin@intel.com>
Reviewed-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Link: https://patchwork.freedesktop.org/patch/msgid/20190607101535.767-1-tvrtko.ursulin@linux.intel.com
parent 7c53c48d
...@@ -68,6 +68,24 @@ struct drm_printer; ...@@ -68,6 +68,24 @@ struct drm_printer;
#define ENGINE_WRITE(...) __ENGINE_WRITE_OP(write, __VA_ARGS__) #define ENGINE_WRITE(...) __ENGINE_WRITE_OP(write, __VA_ARGS__)
#define ENGINE_WRITE_FW(...) __ENGINE_WRITE_OP(write_fw, __VA_ARGS__) #define ENGINE_WRITE_FW(...) __ENGINE_WRITE_OP(write_fw, __VA_ARGS__)
#define GEN6_RING_FAULT_REG_READ(engine__) \
intel_uncore_read((engine__)->uncore, RING_FAULT_REG(engine__))
#define GEN6_RING_FAULT_REG_POSTING_READ(engine__) \
intel_uncore_posting_read((engine__)->uncore, RING_FAULT_REG(engine__))
#define GEN6_RING_FAULT_REG_RMW(engine__, clear__, set__) \
({ \
u32 __val; \
\
__val = intel_uncore_read((engine__)->uncore, \
RING_FAULT_REG(engine__)); \
__val &= ~(clear__); \
__val |= (set__); \
intel_uncore_write((engine__)->uncore, RING_FAULT_REG(engine__), \
__val); \
})
/* seqno size is actually only a uint32, but since we plan to use MI_FLUSH_DW to /* seqno size is actually only a uint32, but since we plan to use MI_FLUSH_DW to
* do the writes, and that must have qw aligned offsets, simply pretend it's 8b. * do the writes, and that must have qw aligned offsets, simply pretend it's 8b.
*/ */
......
...@@ -1195,10 +1195,8 @@ void i915_clear_error_registers(struct drm_i915_private *i915, ...@@ -1195,10 +1195,8 @@ void i915_clear_error_registers(struct drm_i915_private *i915,
enum intel_engine_id id; enum intel_engine_id id;
for_each_engine_masked(engine, i915, engine_mask, id) { for_each_engine_masked(engine, i915, engine_mask, id) {
rmw_clear(uncore, GEN6_RING_FAULT_REG_RMW(engine, RING_FAULT_VALID, 0);
RING_FAULT_REG(engine), RING_FAULT_VALID); GEN6_RING_FAULT_REG_POSTING_READ(engine);
intel_uncore_posting_read(uncore,
RING_FAULT_REG(engine));
} }
} }
} }
......
...@@ -2306,7 +2306,7 @@ static void gen6_check_faults(struct drm_i915_private *dev_priv) ...@@ -2306,7 +2306,7 @@ static void gen6_check_faults(struct drm_i915_private *dev_priv)
u32 fault; u32 fault;
for_each_engine(engine, dev_priv, id) { for_each_engine(engine, dev_priv, id) {
fault = I915_READ(RING_FAULT_REG(engine)); fault = GEN6_RING_FAULT_REG_READ(engine);
if (fault & RING_FAULT_VALID) { if (fault & RING_FAULT_VALID) {
DRM_DEBUG_DRIVER("Unexpected fault\n" DRM_DEBUG_DRIVER("Unexpected fault\n"
"\tAddr: 0x%08lx\n" "\tAddr: 0x%08lx\n"
......
...@@ -1149,7 +1149,7 @@ static void error_record_engine_registers(struct i915_gpu_state *error, ...@@ -1149,7 +1149,7 @@ static void error_record_engine_registers(struct i915_gpu_state *error,
if (INTEL_GEN(dev_priv) >= 8) if (INTEL_GEN(dev_priv) >= 8)
ee->fault_reg = I915_READ(GEN8_RING_FAULT_REG); ee->fault_reg = I915_READ(GEN8_RING_FAULT_REG);
else else
ee->fault_reg = I915_READ(RING_FAULT_REG(engine)); ee->fault_reg = GEN6_RING_FAULT_REG_READ(engine);
} }
if (INTEL_GEN(dev_priv) >= 4) { if (INTEL_GEN(dev_priv) >= 4) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment