[PATCH 05/10] drm/i915: move more pte encoding to pte encode

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, 22 Oct 2012 18:34:10 -0700
Ben Widawsky <ben at bwidawsk.net> wrote:

> In order to handle differences in pte encoding between architectures it
> is desirable to have one helper function, pte_encode, do it all for us.
> As such, this commit moves the code around so we're in good shape to do
> that.
> 
> Luckily the ppgtt pte and the ggtt pte look very similar.
> 
> Signed-off-by: Ben Widawsky <ben at bwidawsk.net>
> ---
>  drivers/gpu/drm/i915/i915_gem_gtt.c | 56 ++++++++++++++++++-------------------
>  1 file changed, 27 insertions(+), 29 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/i915_gem_gtt.c b/drivers/gpu/drm/i915/i915_gem_gtt.c
> index da9c1fa..89c273f 100644
> --- a/drivers/gpu/drm/i915/i915_gem_gtt.c
> +++ b/drivers/gpu/drm/i915/i915_gem_gtt.c
> @@ -33,11 +33,32 @@ typedef uint32_t gtt_pte_t;
>  
>  static inline gtt_pte_t pte_encode(struct drm_device *dev,
>  				   dma_addr_t addr,
> -				   gtt_pte_t cache_bits)
> +				   enum i915_cache_level level)
>  {
>  	gtt_pte_t pte = GEN6_PTE_VALID;
>  	pte |= GEN6_PTE_ADDR_ENCODE(addr);
> -	pte |= cache_bits;
> +
> +	switch (level) {
> +	case I915_CACHE_LLC_MLC:
> +		/* Haswell doesn't set L3 this way */
> +		if (IS_HASWELL(dev))
> +			pte |= GEN6_PTE_CACHE_LLC;
> +		else
> +			pte |= GEN6_PTE_CACHE_LLC_MLC;
> +		break;
> +	case I915_CACHE_LLC:
> +		pte |= GEN6_PTE_CACHE_LLC;
> +		break;
> +	case I915_CACHE_NONE:
> +		if (IS_HASWELL(dev))
> +			pte |= HSW_PTE_UNCACHED;
> +		else
> +			pte |= GEN6_PTE_UNCACHED;
> +		break;
> +	default:
> +		BUG();
> +	}
> +
>  
>  	return pte;
>  }
> @@ -54,7 +75,7 @@ static void i915_ppgtt_clear_range(struct i915_hw_ppgtt *ppgtt,
>  	unsigned last_pte, i;
>  
>  	scratch_pte = pte_encode(ppgtt->dev, ppgtt->scratch_page_dma_addr,
> -				 GEN6_PTE_CACHE_LLC);
> +				 I915_CACHE_LLC);
>  
>  	while (num_entries) {
>  		last_pte = first_pte + num_entries;
> @@ -183,7 +204,7 @@ void i915_gem_cleanup_aliasing_ppgtt(struct drm_device *dev)
>  static void i915_ppgtt_insert_sg_entries(struct i915_hw_ppgtt *ppgtt,
>  					 const struct sg_table *pages,
>  					 unsigned first_entry,
> -					 gtt_pte_t pte_flags)
> +					 enum i915_cache_level cache_level)
>  {
>  	gtt_pte_t *pt_vaddr;
>  	unsigned act_pd = first_entry / I915_PPGTT_PT_ENTRIES;
> @@ -204,7 +225,7 @@ static void i915_ppgtt_insert_sg_entries(struct i915_hw_ppgtt *ppgtt,
>  		for (j = first_pte; j < I915_PPGTT_PT_ENTRIES; j++) {
>  			page_addr = sg_dma_address(sg) + (m << PAGE_SHIFT);
>  			pt_vaddr[j] = pte_encode(ppgtt->dev, page_addr,
> -						 pte_flags);
> +						 cache_level);
>  
>  			/* grab the next page */
>  			if (++m == segment_len) {
> @@ -228,33 +249,10 @@ void i915_ppgtt_bind_object(struct i915_hw_ppgtt *ppgtt,
>  			    struct drm_i915_gem_object *obj,
>  			    enum i915_cache_level cache_level)
>  {
> -	gtt_pte_t pte_flags = GEN6_PTE_VALID;
> -
> -	switch (cache_level) {
> -	case I915_CACHE_LLC_MLC:
> -		/* Haswell doesn't set L3 this way */
> -		if (IS_HASWELL(ppgtt->dev))
> -			pte_flags |= GEN6_PTE_CACHE_LLC;
> -		else
> -			pte_flags |= GEN6_PTE_CACHE_LLC_MLC;
> -		break;
> -	case I915_CACHE_LLC:
> -		pte_flags |= GEN6_PTE_CACHE_LLC;
> -		break;
> -	case I915_CACHE_NONE:
> -		if (IS_HASWELL(ppgtt->dev))
> -			pte_flags |= HSW_PTE_UNCACHED;
> -		else
> -			pte_flags |= GEN6_PTE_UNCACHED;
> -		break;
> -	default:
> -		BUG();
> -	}
> -
>  	i915_ppgtt_insert_sg_entries(ppgtt,
>  				     obj->pages,
>  				     obj->gtt_space->start >> PAGE_SHIFT,
> -				     pte_flags);
> +				     cache_level);
>  }
>  
>  void i915_ppgtt_unbind_object(struct i915_hw_ppgtt *ppgtt,

Reviewed-by: Jesse Barnes <jbarnes at virtuousgeek.org>

-- 
Jesse Barnes, Intel Open Source Technology Center


[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]
  Powered by Linux