[Intel-gfx] [PATCH 05/10] drm/i915: move more pte encoding to pte encode
Jesse Barnes
jbarnes at virtuousgeek.org
Thu Oct 25 22:51:27 CEST 2012
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
More information about the Intel-gfx
mailing list