On Sat, May 09, 2015 at 11:04:28AM +0530, Deepak S wrote: > > > On Friday 08 May 2015 10:09 PM, Ville Syrjälä wrote: > > On Fri, May 08, 2015 at 08:43:12PM +0530, deepa...@linux.intel.com wrote: > >> From: Deepak S <deepa...@linux.intel.com> > >> > >> After feedback from the hardware team, now we set the GPU min/idel freq to > >> RPe. > >> Punit is expecting us to operate GPU between Rpe & Rp0. If we drop the > >> frequency to RPn, punit is failing to change the input voltage to > >> minimum :( > > As I mentioned I've been unable to reproduce that particular problem > > on my BSW. Perhaps add a note about that in the commit message. > > > Issue is Vgg_in voltage not getting dropped :(. Vnn observation is same as > what your seeing.
I think I was observing Vgg, not Vnn. > We saw this issue on CHV platform and confirmed by punit team. > Let me update the commit msg. > > >> Since Punit validates the rps range [RPe, RP0]. This patch > >> removes unused cherryview_rps_min_freq function. > > But I can accept that we should stick to the validated range, so I > > can slap an r-b on the patch anyway: > > Reviewed-by: Ville Syrjälä <ville.syrj...@linux.intel.com> > > > >> v2: Change commit message > >> > >> v3: set min_freq before idle_freq (chris) > >> > >> v4: Squash 'Remove unused rps min function' patch > >> > >> Signed-off-by: Deepak S <deepa...@linux.intel.com> > >> Acked-by: Chris Wilson <ch...@chris-wilson.co.uk> > >> --- > >> drivers/gpu/drm/i915/intel_pm.c | 21 ++------------------- > >> 1 file changed, 2 insertions(+), 19 deletions(-) > >> > >> diff --git a/drivers/gpu/drm/i915/intel_pm.c > >> b/drivers/gpu/drm/i915/intel_pm.c > >> index 852f756..b6b14a4 100644 > >> --- a/drivers/gpu/drm/i915/intel_pm.c > >> +++ b/drivers/gpu/drm/i915/intel_pm.c > >> @@ -4689,24 +4689,6 @@ static int cherryview_rps_guar_freq(struct > >> drm_i915_private *dev_priv) > >> return rp1; > >> } > >> > >> -static int cherryview_rps_min_freq(struct drm_i915_private *dev_priv) > >> -{ > >> - struct drm_device *dev = dev_priv->dev; > >> - u32 val, rpn; > >> - > >> - if (dev->pdev->revision >= 0x20) { > >> - val = vlv_punit_read(dev_priv, FB_GFX_FMIN_AT_VMIN_FUSE); > >> - rpn = ((val >> FB_GFX_FMIN_AT_VMIN_FUSE_SHIFT) & > >> - FB_GFX_FREQ_FUSE_MASK); > >> - } else { /* For pre-production hardware */ > >> - val = vlv_punit_read(dev_priv, PUNIT_GPU_STATUS_REG); > >> - rpn = ((val >> PUNIT_GPU_STATIS_GFX_MIN_FREQ_SHIFT) & > >> - PUNIT_GPU_STATUS_GFX_MIN_FREQ_MASK); > >> - } > >> - > >> - return rpn; > >> -} > >> - > >> static int valleyview_rps_guar_freq(struct drm_i915_private *dev_priv) > >> { > >> u32 val, rp1; > >> @@ -4958,7 +4940,8 @@ static void cherryview_init_gt_powersave(struct > >> drm_device *dev) > >> intel_gpu_freq(dev_priv, dev_priv->rps.rp1_freq), > >> dev_priv->rps.rp1_freq); > >> > >> - dev_priv->rps.min_freq = cherryview_rps_min_freq(dev_priv); > >> + /* PUnit validated range is only [RPe, RP0] */ > >> + dev_priv->rps.min_freq = dev_priv->rps.efficient_freq; > >> DRM_DEBUG_DRIVER("min GPU freq: %d MHz (%u)\n", > >> intel_gpu_freq(dev_priv, dev_priv->rps.min_freq), > >> dev_priv->rps.min_freq); > >> -- > >> 1.9.1 -- Ville Syrjälä Intel OTC _______________________________________________ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/intel-gfx