[Intel-gfx] [PATCH] Revert "drm/i915: Calculate correct stolen size for GEN7+"

Ben Widawsky ben at bwidawsk.net
Wed May 1 20:03:10 CEST 2013


On Wed, May 01, 2013 at 11:00:34AM -0700, Ben Widawsky wrote:
> This reverts commit 03752f5b7b77b95d83479885040950fba1250850.
> 
> This revert requires a bit of explanation on how I understand things
> work. Internally the architects/designers decide how the stolen encoding
> works. We put it in a doc. BIOS writers take these docs and implement
> it. Driver writers read the doc too, and read the value left by the BIOS
> writers, and then we make magic.
> 
> The failing here is that in the docs we had[1] contained two different
> definitions for this register for Gen7. (We have both a PCI register,
> and an MMIO, and each of these were different). At the time [2] of
> 03752f5, we asked the architects what the correct value should be; but
> that doesn't match the reality (BIOS) unfortunately.
> 
> So on all machines I can get my hands on, this revert is the right thing
> to do. I've also worked with the product group to confirm that they
> agree this revert is what we should do. People using HW made my "people"
> who both write their own BIOS, and have access to our docs (Apple?)

Ooops, left this bit out... These "people" may not agree with the
revert. I don't have machines to test.

> 
> [1] The docs are still wrong on this one. Now instead of two registers with
> two definitions, we have one register with BOTH definitions, progress?
> [2] The open source PRMs have the "wrong" definitions in chapter Volume
> 1 part6, section 1.1.12.
> 
> This digging was inspired by Paulo.
> 
> Conflicts:
> 	drivers/gpu/drm/i915/i915_gem_gtt.c
> 
> Cc: Paulo Zanoni <przanoni at gmail.com>
> Signed-off-by: Ben Widawsky <ben at bwidawsk.net>
> ---
>  drivers/gpu/drm/i915/i915_gem_gtt.c | 15 +--------------
>  drivers/gpu/drm/i915/i915_reg.h     |  2 --
>  2 files changed, 1 insertion(+), 16 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/i915_gem_gtt.c b/drivers/gpu/drm/i915/i915_gem_gtt.c
> index 37058ff2..de6e7c5 100644
> --- a/drivers/gpu/drm/i915/i915_gem_gtt.c
> +++ b/drivers/gpu/drm/i915/i915_gem_gtt.c
> @@ -743,15 +743,6 @@ static inline size_t gen6_get_stolen_size(u16 snb_gmch_ctl)
>  	return snb_gmch_ctl << 25; /* 32 MB units */
>  }
>  
> -static inline size_t gen7_get_stolen_size(u16 snb_gmch_ctl)
> -{
> -	static const int stolen_decoder[] = {
> -		0, 0, 0, 0, 0, 32, 48, 64, 128, 256, 96, 160, 224, 352};
> -	snb_gmch_ctl >>= IVB_GMCH_GMS_SHIFT;
> -	snb_gmch_ctl &= IVB_GMCH_GMS_MASK;
> -	return stolen_decoder[snb_gmch_ctl] << 20;
> -}
> -
>  static int gen6_gmch_probe(struct drm_device *dev,
>  			   size_t *gtt_total,
>  			   size_t *stolen,
> @@ -781,11 +772,7 @@ static int gen6_gmch_probe(struct drm_device *dev,
>  	pci_read_config_word(dev->pdev, SNB_GMCH_CTRL, &snb_gmch_ctl);
>  	gtt_size = gen6_get_total_gtt_size(snb_gmch_ctl);
>  
> -	if (IS_GEN7(dev) && !IS_VALLEYVIEW(dev))
> -		*stolen = gen7_get_stolen_size(snb_gmch_ctl);
> -	else
> -		*stolen = gen6_get_stolen_size(snb_gmch_ctl);
> -
> +	*stolen = gen6_get_stolen_size(snb_gmch_ctl);
>  	*gtt_total = (gtt_size / sizeof(gen6_gtt_pte_t)) << PAGE_SHIFT;
>  
>  	/* For Modern GENs the PTEs and register space are split in the BAR */
> diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h
> index 95ae5cf..f2a7a8c 100644
> --- a/drivers/gpu/drm/i915/i915_reg.h
> +++ b/drivers/gpu/drm/i915/i915_reg.h
> @@ -46,8 +46,6 @@
>  #define    SNB_GMCH_GGMS_MASK	0x3
>  #define    SNB_GMCH_GMS_SHIFT   3 /* Graphics Mode Select */
>  #define    SNB_GMCH_GMS_MASK    0x1f
> -#define    IVB_GMCH_GMS_SHIFT   4
> -#define    IVB_GMCH_GMS_MASK    0xf
>  
>  
>  /* PCI config space */
> -- 
> 1.8.2.2
> 

-- 
Ben Widawsky, Intel Open Source Technology Center



More information about the Intel-gfx mailing list