[Intel-gfx] [PATCH 1/2] drm/i915: Enable LVDS downclock feature for LVDS

ykzhao yakui.zhao at intel.com
Fri Nov 20 11:21:48 CET 2009


On Thu, 2009-11-19 at 07:09 +0800, Jesse Barnes wrote:
> On Tue, 17 Nov 2009 17:12:42 +0800
> yakui.zhao at intel.com wrote:
> 
> > From: Zhao Yakui <yakui.zhao at intel.com>
> > 
> > If more than one mode with the same resolution defined in EDID has
> > different refresh rate, it is thought that the downclock is found for
> > LVDS. We will program the different FPx0/1 register so that we can
> > select dynamically between the low and high frequency.
> 
> Cool, we've been wanting this for awhile.
>  
> > On the g4x platform we will use the CxSR feature to switch the
> > different refresh rate if the LVDS downclock feature is supported.
> 
> Great, may as well use the hardware when available...
> 
> > @@ -539,6 +539,8 @@ typedef struct drm_i915_private {
> >  	/* Reclocking support */
> >  	bool render_reclock_avail;
> >  	bool lvds_downclock_avail;
> > +	/* indicates the reduced downclock for LVDS*/
> > +	int	lvds_downclock;
> 
> Weird indentation, a single space should be sufficient.
OK. I will modify it.
> 
> >  /**
> > + * intel_find_lvds_downclock - find the reduced downclock for LVDS
> > in EDID
> > + * @dev: drm device
> > + * @connector: LVDS connector
> > + *
> > + * Find the reduced downclock for LVDS in EDID.
> > + */
> > +static void intel_find_lvds_downclock(struct drm_device *dev,
> > +				struct drm_connector *connector)
> > +{
> > +	struct drm_i915_private *dev_priv = dev->dev_private;
> > +	struct drm_display_mode *scan, *panel_fixed_mode;
> > +
> > +	panel_fixed_mode = dev_priv->panel_fixed_mode;
> > +	list_for_each_entry(scan, &connector->probed_modes, head) {
> > +		mutex_lock(&dev->mode_config.mutex);
> 
> We need to take the mutex across the whole scan, otherwise the list may
> change under us.
OK.
> 
> > @@ -1023,6 +1065,7 @@ void intel_lvds_init(struct drm_device *dev)
> >  			dev_priv->panel_fixed_mode =
> >  				drm_mode_duplicate(dev, scan);
> >  			mutex_unlock(&dev->mode_config.mutex);
> > +			intel_find_lvds_downclock(dev, connector);
> >  			goto out;
> >  		}
> >  		mutex_unlock(&dev->mode_config.mutex);
> 
> Is there a VBT equivalent?  Most of our panel timings come from VBT, so
> if we only support EDID we won't enable the feature very often (it's
> fine to add that as a separate patch though).
I collect some vbios.dumps from some laptops based on 965gm/gm45
platform. 
Unfortunately I don't find that more than one resolution modes with the
resolution has the different refresh rate. 

Of course it seems harmless to check this feature in VBT. I can add this
feature in a separate patch.

thanks for pointing out this issue.
 
> 
> Assuming you fix the above, you can add my Reviewed-by to the patch.
> 
> Thanks,




More information about the Intel-gfx mailing list