diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2017-09-06 11:28:59 -0400 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2017-09-06 12:36:30 -0400 |
commit | 90cad095eeaa43711d60066096cddaf0d3b58bf6 (patch) | |
tree | 4c368d32140891a2bc8132a08a2fb1f374bf4b5d /drivers/gpu/drm/i915/intel_ringbuffer.h | |
parent | 0db8c961209153498fe7e279b8f0d3deb81808f0 (diff) |
drm/i915: Disable MI_STORE_DATA_IMM for i915g/i915gm
The early gen3 machines (i915g/Grantsdale and i915gm/Alviso) share a lot
of characteristics in their MI/GTT blocks with gen2, and in particular
can only use physical addresses in MI_STORE_DATA_IMM. This makes it
incompatible with our usage, so include those two machines in the
blacklist to prevent usage.
v2: Make it easy for gcc and rewrite it as a switch to save some space.
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> #v1
Link: https://patchwork.freedesktop.org/patch/msgid/20170906152859.5304-1-chris@chris-wilson.co.uk
Diffstat (limited to 'drivers/gpu/drm/i915/intel_ringbuffer.h')
-rw-r--r-- | drivers/gpu/drm/i915/intel_ringbuffer.h | 12 |
1 files changed, 1 insertions, 11 deletions
diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.h b/drivers/gpu/drm/i915/intel_ringbuffer.h index 02d8974bf9ab..79c0021f3700 100644 --- a/drivers/gpu/drm/i915/intel_ringbuffer.h +++ b/drivers/gpu/drm/i915/intel_ringbuffer.h | |||
@@ -735,16 +735,6 @@ bool intel_engines_are_idle(struct drm_i915_private *dev_priv); | |||
735 | void intel_engines_mark_idle(struct drm_i915_private *i915); | 735 | void intel_engines_mark_idle(struct drm_i915_private *i915); |
736 | void intel_engines_reset_default_submission(struct drm_i915_private *i915); | 736 | void intel_engines_reset_default_submission(struct drm_i915_private *i915); |
737 | 737 | ||
738 | static inline bool | 738 | bool intel_engine_can_store_dword(struct intel_engine_cs *engine); |
739 | __intel_engine_can_store_dword(unsigned int gen, unsigned int class) | ||
740 | { | ||
741 | if (gen <= 2) | ||
742 | return false; /* uses physical not virtual addresses */ | ||
743 | |||
744 | if (gen == 6 && class == VIDEO_DECODE_CLASS) | ||
745 | return false; /* b0rked */ | ||
746 | |||
747 | return true; | ||
748 | } | ||
749 | 739 | ||
750 | #endif /* _INTEL_RINGBUFFER_H_ */ | 740 | #endif /* _INTEL_RINGBUFFER_H_ */ |