From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ben Widawsky Subject: Re: [PATCH 09/10] drm/i915: enable RC6 workaround on Haswell Date: Mon, 2 Jul 2012 11:40:48 -0700 Message-ID: <20120702114048.26a657c4@bwidawsk.net> References: <1341240671-5843-1-git-send-email-eugeni.dodonov@intel.com> <1341240671-5843-10-git-send-email-eugeni.dodonov@intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: Received: from cloud01.chad-versace.us (184-106-247-128.static.cloud-ips.com [184.106.247.128]) by gabe.freedesktop.org (Postfix) with ESMTP id 6CD839F594 for ; Mon, 2 Jul 2012 11:40:55 -0700 (PDT) In-Reply-To: <1341240671-5843-10-git-send-email-eugeni.dodonov@intel.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: intel-gfx-bounces+gcfxdi-intel-gfx=m.gmane.org@lists.freedesktop.org Errors-To: intel-gfx-bounces+gcfxdi-intel-gfx=m.gmane.org@lists.freedesktop.org To: Eugeni Dodonov Cc: intel-gfx@lists.freedesktop.org List-Id: intel-gfx@lists.freedesktop.org On Mon, 2 Jul 2012 11:51:10 -0300 Eugeni Dodonov wrote: > For Haswell, on some of the early hardware revisions, it is possible to > run into issues when RC6 state is enabled and when pipes change state. > > v2: add comment saying that this is for early revisions only. > > v3: beautify as suggested by Daniel Vetter. > > Signed-off-by: Eugeni Dodonov Acked-by: Ben Widawsky > --- > drivers/gpu/drm/i915/i915_reg.h | 5 +++++ > drivers/gpu/drm/i915/intel_pm.c | 10 ++++++++++ > 2 files changed, 15 insertions(+) > > diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h > index 9d5bf06..793a172 100644 > --- a/drivers/gpu/drm/i915/i915_reg.h > +++ b/drivers/gpu/drm/i915/i915_reg.h > @@ -4516,4 +4516,9 @@ > #define SFUSE_STRAP_DDIC_DETECTED (1<<1) > #define SFUSE_STRAP_DDID_DETECTED (1<<0) > > +#define WM_DBG 0x45280 > +#define WM_DBG_DISALLOW_MULTIPLE_LP (1<<0) > +#define WM_DBG_DISALLOW_MAXFIFO (1<<1) > +#define WM_DBG_DISALLOW_SPRITE (1<<2) > + > #endif /* _I915_REG_H_ */ > diff --git a/drivers/gpu/drm/i915/intel_pm.c b/drivers/gpu/drm/i915/intel_pm.c > index f54196f..604f9bf 100644 > --- a/drivers/gpu/drm/i915/intel_pm.c > +++ b/drivers/gpu/drm/i915/intel_pm.c > @@ -3465,6 +3465,16 @@ static void haswell_init_clock_gating(struct drm_device *dev) > /* WaDisable4x2SubspanOptimization */ > I915_WRITE(CACHE_MODE_1, > _MASKED_BIT_ENABLE(PIXEL_SUBSPAN_COLLECT_OPT_DISABLE)); > + > + /* XXX: This is a workaround for early silicon revisions and should be > + * removed later. > + */ > + I915_WRITE(WM_DBG, > + I915_READ(WM_DBG) | > + WM_DBG_DISALLOW_MULTIPLE_LP | > + WM_DBG_DISALLOW_SPRITE | > + WM_DBG_DISALLOW_MAXFIFO); > + > } > > static void ivybridge_init_clock_gating(struct drm_device *dev) -- Ben Widawsky, Intel Open Source Technology Center