[Intel-gfx] [PATCH 5/8] drm/i915: Disable display when fused off

Daniel Vetter daniel at ffwll.ch
Mon Feb 10 10:12:02 CET 2014


On Fri, Feb 07, 2014 at 07:12:51PM +0000, Damien Lespiau wrote:
> FUSE_STRAP has a bit to inform us that the display has been fused off.
> Use it to setup the definitive number of pipes at run-time.
> 
> v2: actually tweak num_pipes, not num_planes
> v3: also tests SFUSE_STRAP bit 7
> v4: rebase on top of drm-nightly
>     use DRM_INFO() for the message telling display is fused off
>     try to read the FUSE_LOCK bit to determine if PCH display is disabled
> 
> Reviewed-by: Mika Kuoppala <mika.kuoppala at intel.com> (for v3)
> Reviewed-by: Ville Syrjälä <ville.syrjala at linux.intel.com> (for v3)
> Signed-off-by: Damien Lespiau <damien.lespiau at intel.com>
> ---
>  drivers/gpu/drm/i915/i915_dma.c | 31 ++++++++++++++++++++++++++++++-
>  drivers/gpu/drm/i915/i915_reg.h |  2 ++
>  2 files changed, 32 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c
> index e281298..283ace8 100644
> --- a/drivers/gpu/drm/i915/i915_dma.c
> +++ b/drivers/gpu/drm/i915/i915_dma.c
> @@ -1466,16 +1466,45 @@ static void i915_dump_device_info(struct drm_i915_private *dev_priv)
>   *   - it's judged too laborious to fill n static structures with the limit
>   *     when a simple if statement does the job,
>   *   - run-time checks (eg read fuse/strap registers) are needed.
> + *
> + * This function needs to be called:
> + *   - after the MMIO has been setup as we are reading registers,
> + *   - after the PCH has been detected,
> + *   - before the first usage of the fields it can tweak.
>   */
>  static void intel_device_info_runtime_init(struct drm_device *dev)
>  {
> +	struct drm_i915_private *dev_priv = dev->dev_private;
>  	struct intel_device_info *info;
>  
> -	info = (struct intel_device_info *)&to_i915(dev)->info;
> +	info = (struct intel_device_info *)&dev_priv->info;
>  
>  	info->num_sprites = 1;
>  	if (IS_VALLEYVIEW(dev))
>  		info->num_sprites = 2;
> +
> +	if ((INTEL_INFO(dev)->gen == 7 || INTEL_INFO(dev)->gen == 8) &&
> +	    !IS_VALLEYVIEW(dev)) {

I think we need a num_pipes > 0 check here, too. Our display hw guy
expressed surprise that we didn't hang the machine when reading pch
registers on a hsw platform, and Ben learned tha hard way that any such
access on ivb hard-hangs the box. Hence I think we need to retain the
current code's invariant that we never access the pch registers when
num_pipes is 0, like with one of the special pci matching rules.

I've merged the preceding patches to dinq meanwhile.
-Daniel

-- 
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch



More information about the Intel-gfx mailing list