On Wed, Sep 30, 2015 at 03:36:18PM +0100, Michel Thierry wrote:

I made one more change based on profiling:

> diff --git a/drivers/gpu/drm/i915/i915_gem_execbuffer.c 
> b/drivers/gpu/drm/i915/i915_gem_execbuffer.c
> index 67ef118..6ca39c1 100644
> --- a/drivers/gpu/drm/i915/i915_gem_execbuffer.c
> +++ b/drivers/gpu/drm/i915/i915_gem_execbuffer.c
> @@ -589,11 +589,20 @@ i915_gem_execbuffer_reserve_vma(struct i915_vma *vma,
>       if (entry->flags & EXEC_OBJECT_NEEDS_GTT)
>               flags |= PIN_GLOBAL;
>  
> +     /* Wa32bitGeneralStateOffset & Wa32bitInstructionBaseOffset,
> +      * limit address to the first 4GBs for unflagged objects.
> +      */
> +     flags |= PIN_ZONE_4G;
> +     if (entry->flags & EXEC_OBJECT_SUPPORTS_48B_ADDRESS)
> +             flags &= ~PIN_ZONE_4G;
> +
>       if (!drm_mm_node_allocated(&vma->node)) {
                /* Wa32bitGeneralStateOffset & Wa32bitInstructionBaseOffset,
                 * limit address to the first 4GBs for unflagged objects.
                 */
                if ((entry->flags & EXEC_OBJECT_SUPPORTS_48B_ADDRESS) == 0)
                        flags |= PIN_ZONE_4G;

>               if (entry->flags & __EXEC_OBJECT_NEEDS_MAP)
>                       flags |= PIN_GLOBAL | PIN_MAPPABLE;
>               if (entry->flags & __EXEC_OBJECT_NEEDS_BIAS)
>                       flags |= BATCH_OFFSET_BIAS | PIN_OFFSET_BIAS;
> +             if ((flags & PIN_MAPPABLE) == 0)
> +                     flags |= PIN_HIGH;
>       }

It saves me a patch if it we do it now.
-Chris

-- 
Chris Wilson, Intel Open Source Technology Centre
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to