]> git.baikalelectronics.ru Git - kernel.git/commit
drm/i915: Declare the swizzling unknown for L-shaped configurations
authorChris Wilson <chris@chris-wilson.co.uk>
Sun, 28 Jun 2015 08:19:26 +0000 (09:19 +0100)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Thu, 30 Jul 2015 14:51:20 +0000 (16:51 +0200)
commite10fe6f60325f827a4c01792850ee9be2dd371a7
tree3aba1ce758bba36f7f58cc56b0896071b69575f1
parent8bdf6e49e1a8ec748aef7746c8702cfcaee8a7b7
drm/i915: Declare the swizzling unknown for L-shaped configurations

The old style of memory interleaving swizzled upto the end of the
first even bank of memory, and then used the remainder as unswizzled on
the unpaired bank - i.e. swizzling is not constant for all memory. This
causes problems when we try to migrate memory and so the kernel prevents
migration at all when we detect L-shaped inconsistent swizzling.
However, this issue also extends to userspace who try to manually detile
into memory as the swizzling for an individual page is unknown (it
depends on its physical address only known to the kernel), userspace
cannot correctly swizzle.

Note that this is a new attempt for the previously merged one,
reverted in

commit e42511b4a2a56e2a738ac0ae8b4b65425b0bc759
Author: Daniel Vetter <daniel.vetter@ffwll.ch>
Date:   Tue Jul 14 12:29:27 2015 +0200

    Revert "drm/i915: Declare the swizzling unknown for L-shaped configurations"

This is cc: stable since we need it to fix up troubles with wc cpu
mmaps that userspace recently started to use widely.

Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=91105
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
Cc: stable@vger.kernel.org
[danvet: Add note about previous (failed attempt).]
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
drivers/gpu/drm/i915/i915_gem_tiling.c